# TMS320x2805x Piccolo

# **Technical Reference Manual**



Literature Number: SPRUHE5B November 2012–Revised April 2013



# **Contents**

| Pref | ace   |                               |                                                                    | 31        |  |  |  |
|------|-------|-------------------------------|--------------------------------------------------------------------|-----------|--|--|--|
| 1    | Syste | System Control and Interrupts |                                                                    |           |  |  |  |
|      | 1.1   |                               | and OTP Memory                                                     |           |  |  |  |
|      |       | 1.1.1                         | Flash Memory                                                       | 33        |  |  |  |
|      |       | 1.1.2                         | OTP Memory                                                         | 33        |  |  |  |
|      |       | 1.1.3                         | Flash and OTP Power Modes                                          | 34        |  |  |  |
|      |       | 1.1.4                         | Flash and OTP Registers                                            | 39        |  |  |  |
|      | 1.2   | Clocki                        | ng                                                                 | 45        |  |  |  |
|      |       | 1.2.1                         | Clocking and System Control                                        | 45        |  |  |  |
|      |       | 1.2.2                         | OSC and PLL Block                                                  | 51        |  |  |  |
|      |       | 1.2.3                         | Low-Power Modes Block                                              | <b>69</b> |  |  |  |
|      |       | 1.2.4                         | CPU Watchdog Block                                                 | 72        |  |  |  |
|      |       | 1.2.5                         | 32-Bit CPU Timers 0/1/2                                            | 78        |  |  |  |
|      | 1.3   | Gener                         | al-Purpose Input/Output (GPIO)                                     | 83        |  |  |  |
|      |       | 1.3.1                         | GPIO Module Overview                                               | 83        |  |  |  |
|      |       | 1.3.2                         | Configuration Overview                                             | 87        |  |  |  |
|      |       | 1.3.3                         | Digital General Purpose I/O Control                                |           |  |  |  |
|      |       | 1.3.4                         | Input Qualification                                                |           |  |  |  |
|      |       | 1.3.5                         | GPIO and Peripheral Multiplexing (MUX)                             |           |  |  |  |
|      |       | 1.3.6                         | Register Bit Definitions                                           | 99        |  |  |  |
|      | 1.4   | Periph                        | eral Frames                                                        | 115       |  |  |  |
|      |       | 1.4.1                         | Peripheral Frame Registers                                         | 115       |  |  |  |
|      |       | 1.4.2                         | EALLOW-Protected Registers                                         | 117       |  |  |  |
|      |       | 1.4.3                         | Device Emulation Registers                                         | 122       |  |  |  |
|      |       | 1.4.4                         | Write-Followed-by-Read Protection                                  | 124       |  |  |  |
|      | 1.5   | Periph                        | eral Interrupt Expansion (PIE)                                     | 125       |  |  |  |
|      |       | 1.5.1                         | Overview of the PIE Controller                                     | 125       |  |  |  |
|      |       | 1.5.2                         | Vector Table Mapping                                               |           |  |  |  |
|      |       | 1.5.3                         | Interrupt Sources                                                  |           |  |  |  |
|      |       | 1.5.4                         | PIE Configuration Registers                                        | 139       |  |  |  |
|      |       | 1.5.5                         | PIE Interrupt Registers                                            |           |  |  |  |
|      |       | 1.5.6                         | External Interrupt Control Registers                               |           |  |  |  |
|      | 1.6   | VREG                          | /BOR/POR                                                           |           |  |  |  |
|      |       | 1.6.1                         | On-chip Voltage Regulator (VREG)                                   |           |  |  |  |
|      |       | 1.6.2                         | On-chip Power-On Reset (POR) and Brown-Out Reset (BOR) Circuit     |           |  |  |  |
|      | 1.7   | Dual C                        | Code Security Module (DCSM)                                        |           |  |  |  |
|      |       | 1.7.1                         | Functional Description                                             | 151       |  |  |  |
|      |       | 1.7.2                         |                                                                    | 157       |  |  |  |
|      |       | 1.7.3                         | Safe Copy Code                                                     |           |  |  |  |
|      |       | 1.7.4                         | DCSM Impact on Other On-Chip Resources                             |           |  |  |  |
|      |       | 1.7.5                         | Incorporating Code Security in User Applications                   |           |  |  |  |
|      |       | 1.7.6                         | Unsecuring a Zone with Security Enabled (DCSM Password Match Flow) |           |  |  |  |
|      |       | 1.7.7                         | Unsecuring a Zone with Security Disabled                           |           |  |  |  |
|      |       | 1.7.8                         | Environments That Require ECSL Unlocking                           |           |  |  |  |
|      |       | 1.7.9                         | Disabling the ECSL (ECSL Password Match Flow)                      | 162       |  |  |  |

|   |      | 1.7.10         | Do's and Don'ts to Protect Security Logic                         | 164               |
|---|------|----------------|-------------------------------------------------------------------|-------------------|
|   |      | 1.7.11         | Dual Code Security Module Disclaimer                              |                   |
|   | 1.8  | DCSM           | Registers                                                         | 165               |
|   |      | 1.8.1          | DCSM_OTP_Z1 DCSM Registers                                        | 165               |
|   |      | 1.8.2          | DCSM_OTP_Z2 DCSM Registers                                        | 168               |
|   |      | 1.8.3          | DCSM_REGS_COMMON DCSM Registers                                   | 171               |
|   |      | 1.8.4          | DCSM_REGS_Z1 DCSM Registers                                       | 175               |
|   |      | 1.8.5          | DCSM_REGS_Z2 DCSM Registers                                       | 190               |
| 2 | ROM  | Code a         | and Peripheral Booting                                            | 206               |
|   | 2.1  |                | OM                                                                |                   |
|   |      | 2.1.1          | On-Chip Boot ROM IQmath Tables                                    | 208               |
|   |      | 2.1.2          | On-Chip Boot ROM IQmath Functions                                 | 209               |
|   |      | 2.1.3          | On-Chip Flash API                                                 | 210               |
|   |      | 2.1.4          | CPU Vector Table                                                  | 210               |
|   |      | 2.1.5          | Bootloader Features                                               | 212               |
|   |      | 2.1.6          | Building the Boot Table                                           | 249               |
|   |      | 2.1.7          | Bootloader Code Overview                                          | 253               |
|   | 2.2  | CLA D          | ATA ROM                                                           | 254               |
|   |      | 2.2.1          | On-Chip CLA Data ROM Math Tables                                  | 254               |
|   |      | 2.2.2          | CLA DataROM Version and Checksum                                  | 255               |
|   | 2.3  | Secure         | • ROM                                                             | 256               |
|   |      | 2.3.1          | Safe Copy code Functions (Z1 and Z2)                              | 256               |
| 3 | Enha | nced P         | Pulse Width Modulator (ePWM) Module                               | 257               |
|   | 3.1  |                |                                                                   |                   |
|   |      | 3.1.1          | Submodule Overview                                                | 258               |
|   |      | 3.1.2          | Register Mapping                                                  | 261               |
|   | 3.2  | ePWM           | Submodules                                                        | 264               |
|   |      | 3.2.1          | Overview                                                          | 264               |
|   |      | 3.2.2          | Time-Base (TB) Submodule                                          | 266               |
|   |      | 3.2.3          | Counter-Compare (CC) Submodule                                    | 274               |
|   |      | 3.2.4          | Action-Qualifier (AQ) Submodule                                   | 279               |
|   |      | 3.2.5          | Dead-Band Generator (DB) Submodule                                | 293               |
|   |      | 3.2.6          | PWM-Chopper (PC) Submodule                                        | 298               |
|   |      | 3.2.7          | Trip-Zone (TZ) Submodule                                          | 303               |
|   |      | 3.2.8          | Event-Trigger (ET) Submodule                                      | 308               |
|   |      | 3.2.9          | Digital Compare (DC) Submodule                                    | 312               |
|   | 3.3  | Applica        | ations to Power Topologies                                        | 319               |
|   |      | 3.3.1          | Overview of Multiple Modules                                      |                   |
|   |      | 3.3.2          | Key Configuration Capabilities                                    | 319               |
|   |      | 3.3.3          | Controlling Multiple Buck Converters With Independent Frequencies |                   |
|   |      | 3.3.4          | Controlling Multiple Buck Converters With Same Frequencies        |                   |
|   |      | 3.3.5          | Controlling Multiple Half H-Bridge (HHB) Converters               |                   |
|   |      | 3.3.6          | Controlling Dual 3-Phase Inverters for Motors (ACI and PMSM)      |                   |
|   |      | 3.3.7          | Practical Applications Using Phase Control Between PWM Modules    |                   |
|   |      | 3.3.8          | Controlling a 3-Phase Interleaved DC/DC Converter                 |                   |
|   |      | 3.3.9          | Controlling Zero Voltage Switched Full Bridge (ZVSFB) Converter   |                   |
|   |      | 3.3.10         | 5                                                                 |                   |
|   | 3.4  | Regist         |                                                                   |                   |
|   |      |                | Time-Base Submodule Registers                                     | 343               |
|   |      | 3.4.1          | -                                                                 |                   |
|   |      | 3.4.2          | Counter-Compare Submodule Registers                               | 347               |
|   |      | 3.4.2<br>3.4.3 | Counter-Compare Submodule Registers                               | 347<br>350        |
|   |      | 3.4.2          | Counter-Compare Submodule Registers                               | 347<br>350<br>355 |



| ti.com |  |
|--------|--|
|        |  |

|   |                                                                                          | 3.4.6                                                                                                                                                                                                                                                                                                          | Trip-Zone Submodule Control and Status Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 359                                                                                                                                                                                                     |
|---|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                                                                                          | 3.4.7                                                                                                                                                                                                                                                                                                          | Digital Compare Submodule Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 366                                                                                                                                                                                                     |
|   |                                                                                          | 3.4.8                                                                                                                                                                                                                                                                                                          | Event-Trigger Submodule Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 371                                                                                                                                                                                                     |
|   |                                                                                          | 3.4.9                                                                                                                                                                                                                                                                                                          | Proper Interrupt Initialization Procedure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 376                                                                                                                                                                                                     |
| 4 | Enha                                                                                     | nced C                                                                                                                                                                                                                                                                                                         | Capture (eCAP) Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 377                                                                                                                                                                                                     |
| - | 4.1                                                                                      |                                                                                                                                                                                                                                                                                                                | uction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                         |
|   | 4.2                                                                                      |                                                                                                                                                                                                                                                                                                                | ption                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                         |
|   | 4.3                                                                                      |                                                                                                                                                                                                                                                                                                                | re and APWM Operating Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                         |
|   | 4.4                                                                                      |                                                                                                                                                                                                                                                                                                                | re Mode Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                         |
|   |                                                                                          | 4.4.1                                                                                                                                                                                                                                                                                                          | Event Prescaler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                         |
|   |                                                                                          | 4.4.2                                                                                                                                                                                                                                                                                                          | Edge Polarity Select and Qualifier                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                         |
|   |                                                                                          | 4.4.3                                                                                                                                                                                                                                                                                                          | Continuous/One-Shot Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                         |
|   |                                                                                          | 4.4.4                                                                                                                                                                                                                                                                                                          | 32-Bit Counter and Phase Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                         |
|   |                                                                                          | 4.4.5                                                                                                                                                                                                                                                                                                          | CAP1-CAP4 Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                         |
|   |                                                                                          | 4.4.6                                                                                                                                                                                                                                                                                                          | Interrupt Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                         |
|   |                                                                                          | 4.4.7                                                                                                                                                                                                                                                                                                          | Shadow Load and Lockout Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                         |
|   |                                                                                          | 4.4.8                                                                                                                                                                                                                                                                                                          | APWM Mode Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 386                                                                                                                                                                                                     |
|   | 4.5                                                                                      | Captu                                                                                                                                                                                                                                                                                                          | re Module - Control and Status Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                         |
|   | 4.6                                                                                      | •                                                                                                                                                                                                                                                                                                              | er Mapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                         |
|   | 4.7                                                                                      | -                                                                                                                                                                                                                                                                                                              | ation of the ECAP Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                         |
|   |                                                                                          | 4.7.1                                                                                                                                                                                                                                                                                                          | Example 1 - Absolute Time-Stamp Operation Rising Edge Trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 396                                                                                                                                                                                                     |
|   |                                                                                          | 4.7.2                                                                                                                                                                                                                                                                                                          | Example 2 - Absolute Time-Stamp Operation Rising and Falling Edge Trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 399                                                                                                                                                                                                     |
|   |                                                                                          | 4.7.3                                                                                                                                                                                                                                                                                                          | Example 3 - Time Difference (Delta) Operation Rising Edge Trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 401                                                                                                                                                                                                     |
|   |                                                                                          | 4.7.4                                                                                                                                                                                                                                                                                                          | Example 4 - Time Difference (Delta) Operation Rising and Falling Edge Trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 403                                                                                                                                                                                                     |
|   | 4.8                                                                                      | Applic                                                                                                                                                                                                                                                                                                         | ation of the APWM Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 405                                                                                                                                                                                                     |
|   |                                                                                          | 4.8.1                                                                                                                                                                                                                                                                                                          | Example 1 - Simple PWM Generation (Independent Channel/s)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 405                                                                                                                                                                                                     |
|   |                                                                                          |                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                         |
| 5 | Enha                                                                                     | nced C                                                                                                                                                                                                                                                                                                         | QEP (eQEP) Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>407</b>                                                                                                                                                                                              |
| 5 | <b>Enha</b><br>5.1                                                                       |                                                                                                                                                                                                                                                                                                                | QEP (eQEP) Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                         |
| 5 |                                                                                          | Introdu                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 408                                                                                                                                                                                                     |
| 5 | 5.1                                                                                      | Introdu                                                                                                                                                                                                                                                                                                        | uction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 408<br>410                                                                                                                                                                                              |
| 5 | 5.1                                                                                      | Introdu<br>Descri                                                                                                                                                                                                                                                                                              | uction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 408<br>410<br>410                                                                                                                                                                                       |
| 5 | 5.1                                                                                      | Introdu<br>Descri<br>5.2.1                                                                                                                                                                                                                                                                                     | uction<br>ption<br>EQEP Inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 408<br>410<br>410<br>411                                                                                                                                                                                |
| 5 | 5.1                                                                                      | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3                                                                                                                                                                                                                                                                   | eQEP Memory Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 408<br>410<br>410<br>411<br>412<br>413                                                                                                                                                                  |
| 5 | 5.1<br>5.2                                                                               | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3                                                                                                                                                                                                                                                                   | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 408<br>410<br>410<br>411<br>412<br>413<br>413                                                                                                                                                           |
| 5 | 5.1<br>5.2                                                                               | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2                                                                                                                                                                                                                                        | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 408<br>410<br>411<br>412<br>413<br>413<br>413                                                                                                                                                           |
| 5 | 5.1<br>5.2                                                                               | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3                                                                                                                                                                                                                               | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 408<br>410<br>411<br>412<br>413<br>413<br>413<br>416<br>416                                                                                                                                             |
| 5 | 5.1<br>5.2                                                                               | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3                                                                                                                                                                                                                               | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output         on Counter and Control Unit (PCCU)                                                                                                                                                                                                                                                                                                                                                                                                        | 408<br>410<br>411<br>412<br>413<br>413<br>413<br>416<br>416<br>416                                                                                                                                      |
| 5 | 5.1<br>5.2<br>5.3                                                                        | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3                                                                                                                                                                                                                               | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output         on Counter and Control Unit (PCCU)         Position Counter Operating Modes                                                                                                                                                                                                                                                                                                                                                               | 408<br>410<br>411<br>412<br>413<br>413<br>413<br>416<br>416<br>416                                                                                                                                      |
| 5 | 5.1<br>5.2<br>5.3                                                                        | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2                                                                                                                                                                                                  | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output         on Counter operating Modes         Position Counter Latch                                                                                                                                                                                                                                                                                                                                                                                 | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>419                                                                                                                               |
| 5 | 5.1<br>5.2<br>5.3                                                                        | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1                                                                                                                                                                                                           | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output         on Counter and Control Unit (PCCU)         Position Counter Operating Modes         Position Counter Initialization                                                                                                                                                                                                                                                                                                                       | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>419<br>421                                                                                                                        |
| 5 | 5.1<br>5.2<br>5.3<br>5.4                                                                 | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4                                                                                                                                                                                | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output         on Counter and Control Unit (PCCU)         Position Counter Inputation         Position Counter Initialization         eQEP Position-compare Unit                                                                                                                                                                                                                                                                                         | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>419<br>421<br>421                                                                                                          |
| 5 | <ul><li>5.1</li><li>5.2</li><li>5.3</li><li>5.4</li><li>5.5</li></ul>                    | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP                                                                                                                                                                        | uction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output         on Counter and Control Unit (PCCU)         Position Counter Operating Modes         Position Counter Initialization         eQEP Position-compare Unit                                                                                                                                                                                                                                                                                    | 408<br>410<br>411<br>412<br>413<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>419<br>421<br>421<br>423                                                                                     |
| 5 | <ul> <li>5.1</li> <li>5.2</li> <li>5.3</li> <li>5.4</li> <li>5.5</li> <li>5.6</li> </ul> | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP                                                                                                                                                                | Juction         ption         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output         on Counter and Control Unit (PCCU)         Position Counter Inputation         eQEP Position-compare Unit         Equation         Position Counter Initialization         eQEP Position-compare Unit         Edge Capture Unit         Watchdog                                                                                                                                                                                         | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>419<br>421<br>421<br>423<br>426                                                                                     |
| 5 | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7                                            | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>Unit Ti                                                                                                                                                             | Juction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>419<br>421<br>421<br>423<br>426<br>426                                                                              |
| 5 | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8                                     | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP                                                                                                                                             | Juction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>419<br>421<br>421<br>421<br>426<br>426<br>427                                                                       |
| 5 | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7                                            | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP                                                                                                                                             | Juction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>419<br>421<br>421<br>421<br>426<br>426<br>427                                                                       |
| 5 | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9                              | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP<br>eQEP                                                                                                                                     | Juction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>416<br>419<br>421<br>421<br>423<br>426<br>426<br>427                                                                |
|   | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9                              | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP<br>eQEP<br><b>pg-to-D</b>                                                                                                                   | uction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>416<br>419<br>421<br>423<br>426<br>426<br>426<br>427<br>427<br><b>441</b>                                           |
|   | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br><b>Analo</b>              | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP<br>eQEP<br><b>pg-to-D</b>                                                                                                                   | uction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>416<br>421<br>421<br>421<br>422<br>426<br>427<br>427<br><b>441</b><br>442<br>442                                    |
|   | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br><b>Analo</b>              | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP<br>eQEP<br>QEP<br><b>Dg-to-D</b><br>Analog                                                                                                  | uction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>416<br>421<br>421<br>421<br>423<br>426<br>426<br>427<br>427<br>427<br>442<br>442<br>442<br>442                      |
|   | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br><b>Analo</b>              | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP<br>eQEP<br><b>D</b><br><b>d</b><br><b>d</b><br><b>d</b><br><b>d</b><br><b>d</b><br><b>d</b><br><b>d</b><br><b>d</b><br><b>d</b><br><b>d</b> | Justion         EQEP Inputs         Functional Description         eQEP Memory Map         ature Decoder Unit (QDU)         Position Counter Input Modes         eQEP Input Polarity Selection         Position-Compare Sync Output         on Counter and Control Unit (PCCU)         Position Counter Operating Modes         Position Counter Latch         Position Counter Initialization         eQEP Position-compare Unit         Edge Capture Unit         Watchdog         imer Base         Interrupt Structure         Registers         Digital Converter and Comparator         ot-Digital Converter (ADC)         Features         Block Diagram         SOC Principle of Operation | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>416<br>416<br>421<br>421<br>423<br>426<br>426<br>427<br>427<br>427<br>427<br>442<br>442<br>442<br>443               |
|   | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br><b>Analo</b>              | Introdu<br>Descri<br>5.2.1<br>5.2.2<br>5.2.3<br>Quadr<br>5.3.1<br>5.3.2<br>5.3.3<br>Positic<br>5.4.1<br>5.4.2<br>5.4.3<br>5.4.4<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP<br>eQEP<br>Unit Ti<br>eQEP<br>eQEP<br>dnalog<br>6.1.1<br>6.1.2                                                                              | uction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 408<br>410<br>411<br>412<br>413<br>413<br>416<br>416<br>416<br>416<br>416<br>416<br>416<br>421<br>421<br>421<br>422<br>426<br>426<br>426<br>427<br>427<br><b>441</b><br>442<br>442<br>442<br>443<br>447 |

|   |                                                                       | 6.1.6                                                                                                                                                                                                                    | EOC and Interrupt Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 450                                                                                                                                                                                              |
|---|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                                                                       | 6.1.7                                                                                                                                                                                                                    | Power Up Sequence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                  |
|   |                                                                       | 6.1.8                                                                                                                                                                                                                    | ADC Calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                  |
|   |                                                                       | 6.1.9                                                                                                                                                                                                                    | Internal/External Reference Voltage Selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                  |
|   |                                                                       | 6.1.10                                                                                                                                                                                                                   | ADC Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                  |
|   |                                                                       | 6.1.11                                                                                                                                                                                                                   | ADC Timings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                  |
|   |                                                                       | 6.1.12                                                                                                                                                                                                                   | Internal Temperature Sensor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                  |
| 7 | Analo                                                                 | a Fron                                                                                                                                                                                                                   | it-End (AFE) Modules                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                  |
| - | 7.1                                                                   | -                                                                                                                                                                                                                        | mmable Gain Amplifier (PGA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                  |
|   | 7.2                                                                   |                                                                                                                                                                                                                          | d Voltage Reference DAC (VREFOUT)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                  |
|   | 7.3                                                                   |                                                                                                                                                                                                                          | e Comparator and DAC Reference                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                  |
|   | 7.4                                                                   | •                                                                                                                                                                                                                        | Inly Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                  |
|   | 7.5                                                                   |                                                                                                                                                                                                                          | Examples                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                  |
|   |                                                                       | 7.5.1                                                                                                                                                                                                                    | Signal Amplification and Offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                  |
|   | 7.6                                                                   | -                                                                                                                                                                                                                        | Filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                  |
|   | 1.0                                                                   | 7.6.1                                                                                                                                                                                                                    | Filter Behavior                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                  |
|   |                                                                       | 7.6.2                                                                                                                                                                                                                    | Filter Initialization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                  |
|   | 7.7                                                                   |                                                                                                                                                                                                                          | Inder Initialization filter Subsystem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                  |
|   | 1.1                                                                   | 7.7.1                                                                                                                                                                                                                    | Comparator Subsystem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                  |
|   |                                                                       | 7.7.2                                                                                                                                                                                                                    | Digital Filter Subsystem (DFSS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                  |
|   |                                                                       |                                                                                                                                                                                                                          | Comparator Trip (CTRIP) Output Subsystem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                  |
|   | 7.8                                                                   |                                                                                                                                                                                                                          | Front-End and ADC Integration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                  |
|   | 7.9                                                                   | -                                                                                                                                                                                                                        | Front-End and Digital Filter Subsystem Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                  |
|   | 7.5                                                                   | 7.9.1                                                                                                                                                                                                                    | DAC Control Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                  |
|   |                                                                       | 7.9.2                                                                                                                                                                                                                    | DAC, PGA, Comparator, and Filter Enable Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                  |
|   |                                                                       | 7.9.3                                                                                                                                                                                                                    | Switch Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                  |
|   |                                                                       | 7.9.4                                                                                                                                                                                                                    | Digital Filter and Comparator Control Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                  |
|   |                                                                       | 1.3.4                                                                                                                                                                                                                    | • • •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                  |
|   |                                                                       | 795                                                                                                                                                                                                                      | LOCK Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 506                                                                                                                                                                                              |
| 0 | Contr                                                                 | 7.9.5                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                  |
| 8 |                                                                       | ol Law                                                                                                                                                                                                                   | Accelerator (CLA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 510                                                                                                                                                                                              |
| 8 | 8.1                                                                   | ol Law<br>Control                                                                                                                                                                                                        | Accelerator (CLA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <b>510</b><br>511                                                                                                                                                                                |
| 8 |                                                                       | ol Law<br>Control<br>CLA In                                                                                                                                                                                              | Accelerator (CLA)<br>I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>510</b><br>511<br>513                                                                                                                                                                         |
| 8 | 8.1                                                                   | Control<br>CLA In<br>8.2.1                                                                                                                                                                                               | Accelerator (CLA)<br>I Law Accelerator (CLA) Overview<br>terface<br>CLA Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <b>510</b><br>511<br>513<br>513                                                                                                                                                                  |
| 8 | 8.1                                                                   | Control<br>CLA In<br>8.2.1<br>8.2.2                                                                                                                                                                                      | Accelerator (CLA)<br>I Law Accelerator (CLA) Overview<br>terface<br>CLA Memory<br>CLA Memory Bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>510</b><br>511<br>513<br>513<br>514                                                                                                                                                           |
| 8 | 8.1                                                                   | Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3                                                                                                                                                                             | Accelerator (CLA)<br>I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>510</b><br>511<br>513<br>513<br>514<br>514                                                                                                                                                    |
| 8 | 8.1<br>8.2                                                            | Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4                                                                                                                                                                    | Accelerator (CLA)<br>I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>510</b><br>511<br>513<br>513<br>514<br>514<br>514                                                                                                                                             |
| 8 | 8.1                                                                   | Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co                                                                                                                                                          | Accelerator (CLA)<br>I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>510</b><br>511<br>513<br>513<br>514<br>514<br>515<br>516                                                                                                                                      |
| 8 | 8.1<br>8.2                                                            | OI Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1                                                                                                                                       | Accelerator (CLA)<br>I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>510</b><br>511<br>513<br>513<br>514<br>514<br>515<br>516<br>516                                                                                                                               |
| 8 | 8.1<br>8.2                                                            | OI Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2                                                                                                                              | Accelerator (CLA) I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>510</b><br>513<br>513<br>514<br>514<br>515<br>516<br>516<br>516                                                                                                                               |
| 8 | 8.1<br>8.2                                                            | OI Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3                                                                                                                     | Accelerator (CLA) I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>510</b><br>511<br>513<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>518                                                                                                                 |
| 8 | 8.1<br>8.2                                                            | Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4                                                                                                                      | Accelerator (CLA)<br>I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>518<br>519                                                                                                                 |
| 8 | 8.1<br>8.2<br>8.3                                                     | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5                                                                                                   | Accelerator (CLA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <b>510</b><br>511<br>513<br>514<br>514<br>514<br>515<br>516<br>516<br>516<br>518<br>519<br>519                                                                                                   |
| 8 | 8.1<br>8.2                                                            | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Register                                                                                       | Accelerator (CLA) I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>510</b><br>511<br>513<br>514<br>514<br>514<br>516<br>516<br>516<br>516<br>518<br>519<br>519<br>520                                                                                            |
| 8 | 8.1<br>8.2<br>8.3                                                     | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1                                                                               | Accelerator (CLA)         I Law Accelerator (CLA) Overview         terface         CLA Memory         CLA Memory Bus         Shared Peripherals and EALLOW Protection         CLA Tasks and Interrupt Vectors         onfiguration and Debug         Building a CLA Application         Typical CLA Initialization Sequence         Debugging CLA Code         CLA Illegal Opcode Behavior         Resetting the CLA         Register Memory Mapping                                                                                                                                                                                       | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>518<br>519<br>519<br>520<br>520                                                                                     |
| 8 | 8.1<br>8.2<br>8.3                                                     | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2                                                                      | Accelerator (CLA)         I Law Accelerator (CLA) Overview         terface         CLA Memory         CLA Memory Bus         Shared Peripherals and EALLOW Protection         CLA Tasks and Interrupt Vectors         onfiguration and Debug         Building a CLA Application         Typical CLA Initialization Sequence         Debugging CLA Code         CLA Illegal Opcode Behavior         Resetting the CLA         ar Set         Register Memory Mapping         Task Interrupt Vector Registers                                                                                                                                | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>520<br>521                                                                                     |
| 8 | 8.1<br>8.2<br>8.3                                                     | Ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2<br>8.4.3                                                             | Accelerator (CLA)         I Law Accelerator (CLA) Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>520<br>521<br>522                                                                              |
| 8 | <ul><li>8.1</li><li>8.2</li><li>8.3</li><li>8.4</li></ul>             | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Cd<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4                                                    | Accelerator (CLA)         I Law Accelerator (CLA) Overview         terface         CLA Memory         CLA Memory Bus         Shared Peripherals and EALLOW Protection         CLA Tasks and Interrupt Vectors         configuration and Debug         Building a CLA Application         Typical CLA Initialization Sequence         Debugging CLA Code         CLA Illegal Opcode Behavior         Resetting the CLA         ar Set         Register Memory Mapping         Task Interrupt Vector Registers         Configuration Registers                                                                                               | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>520<br>520<br>521<br>522<br>522<br>534                                                         |
| 8 | 8.1<br>8.2<br>8.3                                                     | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>Pipeline                                        | Accelerator (CLA)         I Law Accelerator (CLA) Overview         terface         CLA Memory         CLA Memory Bus         Shared Peripherals and EALLOW Protection         CLA Tasks and Interrupt Vectors         onfiguration and Debug         Building a CLA Application         Typical CLA Initialization Sequence         Debugging CLA Code         CLA Illegal Opcode Behavior         Resetting the CLA         ar Set         Task Interrupt Vector Registers         Configuration Registers         Execution Registers                                                                                                    | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>520<br>520<br>521<br>522<br>521<br>522<br>534<br>537                                           |
| 8 | <ul><li>8.1</li><li>8.2</li><li>8.3</li><li>8.4</li></ul>             | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>Pipelino<br>8.5.1                               | Accelerator (CLA)         I Law Accelerator (CLA) Overview         terface         CLA Memory         CLA Memory Bus         Shared Peripherals and EALLOW Protection         CLA Tasks and Interrupt Vectors         onfiguration and Debug         Building a CLA Application         Typical CLA Initialization Sequence         Debugging CLA Code         CLA Illegal Opcode Behavior         Resetting the CLA         ar Set         Register Memory Mapping         Task Interrupt Vector Registers         Configuration Registers         Periphine Overview                                                                     | <b>510</b><br>511<br>513<br>514<br>514<br>516<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>520<br>520<br>521<br>522<br>521<br>522<br>5234<br>537                                          |
| 8 | <ul><li>8.1</li><li>8.2</li><li>8.3</li><li>8.4</li></ul>             | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>Pipeline<br>8.5.1<br>8.5.2                      | Accelerator (CLA)         I Law Accelerator (CLA) Overview         terface         CLA Memory         CLA Memory Bus         Shared Peripherals and EALLOW Protection         CLA Tasks and Interrupt Vectors         onfiguration and Debug         Building a CLA Application         Typical CLA Initialization Sequence         Debugging CLA Code         CLA Illegal Opcode Behavior         Resetting the CLA         er Set         Register Memory Mapping         Task Interrupt Vector Registers         Configuration Registers         Execution Registers         e         Pipeline Overview         CLA Pipeline Alignment | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>521<br>520<br>521<br>522<br>521<br>522<br>534<br>537<br>537                                    |
| 8 | <ul><li>8.1</li><li>8.2</li><li>8.3</li><li>8.4</li><li>8.5</li></ul> | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>Pipelino<br>8.5.1<br>8.5.2<br>8.5.3             | Accelerator (CLA)         I Law Accelerator (CLA) Overview         terface         CLA Memory         CLA Memory Bus         Shared Peripherals and EALLOW Protection         CLA Tasks and Interrupt Vectors         onfiguration and Debug         Building a CLA Application         Typical CLA Initialization Sequence         Debugging CLA Code         CLA Illegal Opcode Behavior         Resetting the CLA         er Set         Configuration Registers         Execution Registers         Execution Registers         e         Pipeline Overview         CLA Pipeline Alignment         Parallel Instructions               | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>521<br>520<br>521<br>522<br>521<br>522<br>534<br>537<br>537<br>537                             |
| 8 | <ul><li>8.1</li><li>8.2</li><li>8.3</li><li>8.4</li></ul>             | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Cd<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>Pipeline<br>8.5.1<br>8.5.2<br>8.5.3<br>Instruct | Accelerator (CLA) I Law Accelerator (CLA) Overview terface CLA Memory CLA Memory CLA Memory Bus Shared Peripherals and EALLOW Protection CLA Tasks and Interrupt Vectors onfiguration and Debug Building a CLA Application Typical CLA Initialization Sequence Debugging CLA Code CLA Illegal Opcode Behavior Resetting the CLA er Set Register Memory Mapping Task Interrupt Vector Registers Configuration Registers Execution Registers e Pipeline Overview CLA Pipeline Alignment Parallel Instructions tion Set                                                                                                                       | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>521<br>520<br>521<br>522<br>534<br>522<br>534<br>537<br>537<br>537<br>540<br>542        |
| 8 | <ul><li>8.1</li><li>8.2</li><li>8.3</li><li>8.4</li><li>8.5</li></ul> | ol Law<br>Control<br>CLA In<br>8.2.1<br>8.2.2<br>8.2.3<br>8.2.4<br>CLA Co<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>Registe<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>Pipelino<br>8.5.1<br>8.5.2<br>8.5.3             | Accelerator (CLA)         I Law Accelerator (CLA) Overview         terface         CLA Memory         CLA Memory Bus         Shared Peripherals and EALLOW Protection         CLA Tasks and Interrupt Vectors         onfiguration and Debug         Building a CLA Application         Typical CLA Initialization Sequence         Debugging CLA Code         CLA Illegal Opcode Behavior         Resetting the CLA         er Set         Configuration Registers         Execution Registers         Execution Registers         e         Pipeline Overview         CLA Pipeline Alignment         Parallel Instructions               | <b>510</b><br>511<br>513<br>514<br>514<br>515<br>516<br>516<br>516<br>516<br>518<br>519<br>520<br>521<br>520<br>521<br>522<br>521<br>522<br>534<br>537<br>537<br>537<br>537<br>540<br>542<br>542 |



| www.     | +;  | ~~m   |
|----------|-----|-------|
| vv vv vv | .u. | COIII |

|    |         | 8.6.3    | Instructions                                      | 546        |
|----|---------|----------|---------------------------------------------------|------------|
|    | 8.7     |          | dix A: CLA and CPU Arbitration                    |            |
|    |         | •••      | CLA and CPU Arbitration                           |            |
| 9  | Inter-I | ntegra   | ted Circuit (I2C) Module                          | 659        |
| •  | 9.1     | -        | ction to the I2C Module                           |            |
|    | 0.1     | 9.1.1    | Features                                          |            |
|    |         |          | Features Not Supported                            |            |
|    |         |          | Functional Overview                               |            |
|    |         |          | Clock Generation                                  |            |
|    | 9.2     |          | dule Operational Details                          |            |
|    |         | 9.2.1    | Input and Output Voltage Levels                   |            |
|    |         | 9.2.2    | Data Validity                                     |            |
|    |         |          | Operating Modes                                   |            |
|    |         |          | I2C Module START and STOP Conditions              |            |
|    |         | 9.2.5    | Serial Data Formats                               | 665        |
|    |         | 9.2.6    | NACK Bit Generation                               |            |
|    |         | 9.2.7    | Clock Synchronization                             |            |
|    |         | 9.2.8    | Arbitration                                       |            |
|    | 9.3     | Interrup | ot Requests Generated by the I2C Module           | 669        |
|    |         | 9.3.1    | Basic I2C Interrupt Requests                      | 669        |
|    |         | 9.3.2    | I2C FIFO Interrupts                               | 670        |
|    | 9.4     | Resetti  | ng/Disabling the I2C Module                       | 670        |
|    | 9.5     | I2C Mo   | dule Registers                                    | 670        |
|    |         | 9.5.1    | I2C Mode Register (I2CMDR)                        | 672        |
|    |         | 9.5.2    | I2C Extended Mode Register (I2CEMDR)              | 675        |
|    |         | 9.5.3    | I2C Interrupt Enable Register (I2CIER)            | 677        |
|    |         | 9.5.4    | I2C Status Register (I2CSTR)                      | 677        |
|    |         | 9.5.5    | I2C Interrupt Source Register (I2CISRC)           | <b>680</b> |
|    |         | 9.5.6    | I2C Prescaler Register (I2CPSC)                   | <u>681</u> |
|    |         | 9.5.7    | I2C Clock Divider Registers (I2CCLKL and I2CCLKH) | 682        |
|    |         | 9.5.8    | I2C Slave Address Register (I2CSAR)               |            |
|    |         | 9.5.9    | I2C Own Address Register (I2COAR)                 |            |
|    |         | 9.5.10   | I2C Data Count Register (I2CCNT)                  |            |
|    |         | 9.5.11   | I2C Data Receive Register (I2CDRR)                |            |
|    |         |          | I2C Data Transmit Register (I2CDXR)               |            |
|    |         |          | I2C Transmit FIFO Register (I2CFFTX)              |            |
|    |         | 9.5.14   | I2C Receive FIFO Register (I2CFFRX)               | 686        |
| 10 | Serial  | Periph   | neral Interface (SPI)                             | <b>688</b> |
|    | 10.1    | Enhand   | ced SPI Module Overview                           | 689        |
|    |         | 10.1.1   | SPI Block Diagram                                 | <b>690</b> |
|    |         | 10.1.2   | SPI Module Signal Summary                         | 692        |
|    |         | 10.1.3   | Overview of SPI Module Registers                  | 692        |
|    |         |          | SPI Operation                                     |            |
|    |         | 10.1.5   | SPI Interrupts                                    | 695        |
|    |         | 10.1.6   | SPI FIFO Description                              | 700        |
|    |         |          | SPI 3-Wire Mode Description                       |            |
|    | 10.2    |          | gisters and Waveforms                             |            |
|    |         |          | SPI Control Registers                             |            |
|    |         | 10.2.2   | SPI Example Waveforms                             | 714        |
| 11 | Serial  | Comm     | nunications Interface (SCI)                       | 718        |
|    | 11.1    | Enhand   | ced SCI Module Overview                           | 719        |
|    |         | 11.1.1   | Architecture                                      | 720        |

TEXAS INSTRUMENTS

| www. | ti.com |         |                                                     |     |
|------|--------|---------|-----------------------------------------------------|-----|
|      | 11.2   | SCI Reg | gisters                                             | 732 |
|      |        |         | SCI Module Register Summary                         |     |
|      |        |         | SCI Communication Control Register (SCICCR)         |     |
|      |        | 11.2.3  | SCI Control Register 1 (SCICTL1)                    |     |
|      |        | 11.2.4  | SCI Baud-Select Registers (SCIHBAUD, SCILBAUD)      |     |
|      |        | 11.2.5  | SCI Control Register 2 (SCICTL2)                    |     |
|      |        | 11.2.6  | SCI Receiver Status Register (SCIRXST)              |     |
|      |        | 11.2.7  | Receiver Data Buffer Registers (SCIRXEMU, SCIRXBUF) |     |
|      |        | 11.2.8  | SCI Transmit Data Buffer Register (SCITXBUF)        |     |
|      |        | 11.2.9  | SCI FIFO Registers (SCIFFTX, SCIFFRX, SCIFFCT)      |     |
|      |        | 11.2.10 | Priority Control Register (SCIPRI)                  | 745 |
| 12   | Fnha   |         | ontroller Area Network (eCAN)                       |     |
|      | 12.1   |         | verview                                             |     |
|      |        | 12.1.1  | Features                                            |     |
|      |        | 12.1.2  | Block Diagram                                       |     |
|      |        |         | eCAN Compatibility With Other TI CAN Modules        |     |
|      | 12.2   |         | N Network and Module                                |     |
|      | 12.2   |         | CAN Protocol Overview                               |     |
|      | 12.3   |         | Controller Overview                                 |     |
|      | 12.0   | 12.3.1  | Standard CAN Controller (SCC) Mode                  |     |
|      |        | 12.3.2  | Memory Map                                          |     |
|      |        |         | eCAN Control and Status Registers                   |     |
|      | 12.4   |         | e Objects                                           |     |
|      | 12.5   | -       | e Objects                                           |     |
|      | 12.0   | •       | Transmit Mailbox                                    |     |
|      |        | 12.5.2  | Receive Mailbox                                     |     |
|      |        | -       | CAN Module Operation in Normal Configuration        |     |
|      | 12.6   |         | Registers                                           |     |
|      | 12.0   | 12.6.1  | Mailbox Enable Register (CANME)                     |     |
|      |        | 12.6.2  | Mailbox-Direction Register (CANMD)                  |     |
|      |        | 12.6.3  | Transmission-Request Set Register (CANTRS)          |     |
|      |        | 12.6.4  | Transmission-Request-Reset Register (CANTRR)        |     |
|      |        | 12.6.5  | Transmission-Acknowledge Register (CANTA)           |     |
|      |        |         | Abort-Acknowledge Register (CANAA)                  |     |
|      |        |         | Received-Message-Pending Register (CANRMP)          | 765 |
|      |        | 12.6.8  | Received-Message-Lost Register (CANRML)             |     |
|      |        | 12.6.9  | Remote-Frame-Pending Register (CANRFP)              |     |
|      |        |         | Global Acceptance Mask Register (CANGAM)            |     |
|      |        | 12.6.11 |                                                     |     |
|      |        |         | Bit-Timing Configuration Register (CANBTC)          |     |
|      |        |         | Error and Status Register (CANES)                   |     |
|      |        |         | CAN Error Counter Registers (CANTEC/CANREC)         |     |
|      |        | 12.6.15 |                                                     |     |
|      |        | 12.6.16 |                                                     |     |
|      |        | 12.6.17 |                                                     |     |
|      |        | 12.6.18 |                                                     |     |
|      |        | 12.6.19 | •                                                   |     |
|      |        | 12.6.20 |                                                     |     |
|      | 12.7   |         | Configuration                                       |     |
|      | 12.1   | 12.7.1  | CAN Module Initialization                           |     |
|      |        | 12.7.1  | Steps to Configure eCAN                             |     |
|      |        | 12.7.2  | Handling of Remote Frame Mailboxes                  |     |
|      |        | 12.7.3  | Interrupts                                          |     |
|      |        | 12.1.4  |                                                     | 000 |

Contents



|   | 12.7.5 CAN Power-Down Mode 81 | 11 |
|---|-------------------------------|----|
| Α | Revision History              | 13 |



# List of Figures

| 1-1.                    | Flash Power Mode State Diagram                              | 35         |
|-------------------------|-------------------------------------------------------------|------------|
| 1-2.                    | Flash Pipeline                                              | 37         |
| 1-3.                    | Flash Configuration Access Flow Diagram                     | 38         |
| 1-4.                    | Flash Options Register (FOPT)                               | 40         |
| 1-5.                    | Flash Power Register (FPWR)                                 | 40         |
| 1-6.                    | Flash Status Register (FSTATUS)                             | 41         |
| 1-7.                    | Flash Standby Wait Register (FSTDBYWAIT)                    | 42         |
| 1-8.                    | Flash Standby to Active Wait Counter Register (FACTIVEWAIT) | 42         |
| 1-9.                    | Flash Wait-State Register (FBANKWAIT)                       | 43         |
| 1-10.                   | OTP Wait-State Register (FOTPWAIT)                          | 44         |
| 1-11.                   | Clock and Reset Domains                                     | 45         |
| 1-12.                   | Peripheral Clock Control 0 Register (PCLKCR0)               | 46         |
| 1-13.                   | Peripheral Clock Control 1 Register (PCLKCR1)               | 48         |
| 1-14.                   | Peripheral Clock Control 3 Register (PCLKCR3)               | 49         |
| 1-15.                   | Peripheral Clock Control 4 Register (PCLKCR4)               | <b>50</b>  |
| 1-16.                   | Low-Speed Peripheral Clock Prescaler Register (LOSPCP)      | 51         |
| 1-17.                   | Clocking Options                                            | 52         |
| 1-18.                   | Internal Oscillator n Trim (INTOSCnTRIM) Register           | 53         |
| 1-19.                   | Clocking (XCLK) Register                                    | 54         |
| 1-20.                   | Clock Control (CLKCTL) Register                             | 54         |
| 1-21.                   | OSC and PLL Block                                           | 57         |
| 1-22.                   | Oscillator Logic Diagram                                    | 58         |
| 1-23.                   | Clock Fail Interrupt                                        | 61         |
| 1-24.                   | XCLKOUT Generation                                          | <b>6</b> 4 |
| 1-25.                   | PLLCR Change Procedure Flow Chart                           | 65         |
| 1-26.                   | PLLCR Register Layout                                       | 66         |
| 1-27.                   | PLL Status Register (PLLSTS)                                | 66         |
| 1-28.                   | PLL Lock Period (PLLLOCKPRD) Register                       | <b>68</b>  |
| 1-29.                   | Low Power Mode Control 0 Register (LPMCR0)                  | 70         |
| 1-30.                   | CPU Watchdog Module                                         | 72         |
| 1-31.                   | System Control and Status Register (SCSR)                   | 75         |
| 1-32.                   | Watchdog Counter Register (WDCNTR)                          | 76         |
| 1-33.                   | Watchdog Reset Key Register (WDKEY)                         | 76         |
| 1-34.                   | Watchdog Control Register (WDCR)                            | 76         |
| 1-35.                   | CPU-Timers                                                  | 78         |
| 1-36.                   | CPU-Timer Interrupts Signals and Output Signal              | 78         |
| 1-37.                   | TIMERxTIM Register (x = 1, 2, 3)                            | 79         |
| 1-38.                   | TIMERxTIMH Register (x = 1, 2, 3)                           | 79         |
| 1-39.                   | TIMERxPRD Register (x = 1, 2, 3)                            | 80         |
| 1-40.                   | TIMERxPRDH Register (x = 1, 2, 3)                           | 80         |
| 1-41.                   | TIMERxTCR Register (x = 1, 2, 3)                            | 80         |
| 1-42.                   | TIMERxTPR Register (x = 1, 2, 3)                            | 81         |
| 1-43.                   | TIMERxTPRH Register (x = 1, 2, 3)                           | 82         |
| 1-44.                   | GPIO0 to GPIO31 Multiplexing Diagram                        | 84         |
|                         |                                                             |            |
| 1-45.                   | GPIO32 to GPIO40, GPIO42 Multiplexing Diagram               |            |
| 1-45.<br>1-46.<br>1-47. |                                                             | 86         |



| ww |  |  |
|----|--|--|
|    |  |  |
|    |  |  |

| 1-48. | Input Qualifier Clock Cycles                                              |     |
|-------|---------------------------------------------------------------------------|-----|
| 1-49. | GPIO Port A MUX 1 (GPAMUX1) Register                                      |     |
| 1-50. | GPIO Port A MUX 2 (GPAMUX2) Register                                      | 101 |
| 1-51. | GPIO Port B MUX 1 (GPBMUX1) Register                                      | 103 |
| 1-52. | GPIO Port A Qualification Control (GPACTRL) Register                      | 105 |
| 1-53. | GPIO Port B Qualification Control (GPBCTRL) Register                      | 106 |
| 1-54. | GPIO Port A Qualification Select 1 (GPAQSEL1) Register                    | 107 |
| 1-55. | GPIO Port A Qualification Select 2 (GPAQSEL2) Register                    | 107 |
| 1-56. | GPIO Port B Qualification Select 1 (GPBQSEL1) Register                    | 108 |
| 1-57. | GPIO Port A Direction (GPADIR) Register                                   | 108 |
| 1-58. | GPIO Port B Direction (GPBDIR) Register                                   | 109 |
| 1-59. | GPIO Port A Pullup Disable (GPAPUD) Registers                             | 109 |
| 1-60. | GPIO Port B Pullup Disable (GPBPUD) Registers                             | 110 |
| 1-61. | GPIO Port A Data (GPADAT) Register                                        | 110 |
| 1-62. | GPIO Port B Data (GPBDAT) Register                                        | 111 |
| 1-63. | GPIO Port A Set, Clear and Toggle (GPASET, GPACLEAR, GPATOGGLE) Registers | 112 |
| 1-64. | GPIO Port B Set, Clear and Toggle (GPBSET, GPBCLEAR, GPBTOGGLE) Registers | 112 |
| 1-65. | GPIO XINTn Interrupt Select (GPIOXINTnSEL) Registers                      | 113 |
| 1-66. | GPIO Low Power Mode Wakeup Select (GPIOLPMSEL) Register                   | 114 |
| 1-67. | Device Configuration (DEVICECNF) Register                                 | 122 |
| 1-68. | Part ID Register                                                          | 123 |
| 1-69. | REVID Register                                                            | 123 |
| 1-70. | Overview: Multiplexing of Interrupts Using the PIE Block                  | 125 |
| 1-71. | Typical PIE/CPU Interrupt Response - INTx.y                               | 127 |
| 1-72. | Reset Flow Diagram                                                        | 129 |
| 1-73. | PIE Interrupt Sources and External Interrupts XINT1/XINT2/XINT3           | 130 |
| 1-74. | Multiplexed Interrupt Request Flow Diagram                                | 133 |
| 1-75. | PIECTRL Register (Address 0xCE0)                                          | 140 |
| 1-76. | PIE Interrupt Acknowledge Register (PIEACK) Register (Address 0xCE1)      | 140 |
| 1-77. | PIEIFRx Register (x = 1 to 12)                                            | 141 |
| 1-78. | PIEIERx Register (x = 1 to 12)                                            | 141 |
| 1-79. | Interrupt Flag Register (IFR) — CPU Register                              | 143 |
| 1-80. | Interrupt Enable Register (IER) — CPU Register                            | 145 |
| 1-81. | Debug Interrupt Enable Register (DBGIER) — CPU Register                   | 146 |
| 1-82. | External Interrupt <i>n</i> Control Register (XINT <i>n</i> CR)           | 148 |
| 1-83. | External Interrupt n Counter (XINTnCTR) (Address 7078h)                   | 149 |
| 1-84. | BOR Configuration (BORCFG) Register                                       | 151 |
| 1-85. | Storage of Zone Select bits in OTP                                        | 155 |
| 1-86. | DCSM Password Match Flow                                                  | 160 |
| 1-87. | ECSL Password Match Flow                                                  | 163 |
| 1-88. | Z1_LINKPOINTER Register                                                   | 166 |
| 1-89. | Z1_OTPSECLOCK Register                                                    | 167 |
| 1-90. | Z1_BOOTMODE Register                                                      | 168 |
| 1-91. | Z2_LINKPOINTER Register                                                   | 169 |
| 1-92. | Z2_OTPSECLOCK Register                                                    | 170 |
| 1-93. | Z2_BOOTMODE Register                                                      | 171 |
| 1-94. | FLSEM Register                                                            | 172 |
| 1-95. | SECTSTAT Register                                                         | 173 |
| 1-96. | RAMSTAT Register                                                          | 175 |
| 1 00. |                                                                           |     |

| www.ti.com |                                                |     |
|------------|------------------------------------------------|-----|
| 1-97.      | Z1_LINKPOINTER Register                        | 177 |
|            | Z1_OTPSECLOCK Register                         | 178 |
| 1-99.      | Z1_BOOTMODE Register                           | 179 |
| 1-100.     | Z1_CSMKEY0 Register                            | 180 |
| 1-101.     | Z1_CSMKEY1 Register                            | 181 |
| 1-102.     | Z1_CSMKEY2 Register                            | 182 |
| 1-103.     | Z1_CSMKEY3 Register                            | 183 |
| 1-104.     | Z1_CR Register                                 | 184 |
| 1-105.     | Z1_GRABSECTR Register                          | 185 |
| 1-106.     | Z1_GRABRAMR Register                           | 187 |
| 1-107.     | Z1_EXEONLYSECTR Register                       | 188 |
| 1-108.     | Z1_EXEONLYRAMR Register                        | 190 |
| 1-109.     | Z2_LINKPOINTER Register                        | 192 |
| 1-110.     | Z2_OTPSECLOCK Register                         | 193 |
| 1-111.     | Z2_BOOTMODE Register                           | 194 |
| 1-112.     | Z2_CSMKEY0 Register                            | 195 |
| 1-113.     | Z2_CSMKEY1 Register                            | 196 |
| 1-114.     | Z2_CSMKEY2 Register                            | 197 |
| 1-115.     | Z2_CSMKEY3 Register                            | 198 |
| 1-116.     | Z2_CR Register                                 | 199 |
| 1-117.     | Z2_GRABSECTR Register                          | 200 |
| 1-118.     | Z2_GRABRAMR Register                           | 202 |
| 1-119.     | Z2_EXEONLYSECTR Register                       | 203 |
| 1-120.     | Z2_EXEONLYRAMR Register                        | 205 |
| 2-1.       | Memory Map of On-Chip ROM                      | 207 |
| 2-2.       | Vector Table Map                               | 210 |
| 2-3.       | Bootloader Flow Diagram                        | 213 |
| 2-4.       | Boot ROM Stack                                 | 215 |
| 2-5.       | Boot ROM Function Overview                     | 217 |
| 2-6.       | GetMode Flowchart                              | 220 |
| 2-7.       | Bootloader Basic Transfer Procedure            | 229 |
| 2-8.       | Init Boot Routine Flow Chart                   | 231 |
| 2-9.       | Overview of the SelectBootMode Function        | 232 |
| 2-10.      | Overview of CopyData Function                  | 233 |
| 2-11.      | Overview of SCI Bootloader Operation           | 233 |
| 2-12.      | Overview of SCI_Boot Function                  | 234 |
| 2-13.      | Overview of SCI_GetWordData Function           | 235 |
| 2-14.      | Overview of Parallel GPIO Bootloader Operation | 235 |
| 2-15.      | Parallel GPIO Boot Loader Handshake Protocol   | 236 |
| 2-16.      | Parallel GPIO Mode Overview                    | 237 |
| 2-17.      | Parallel GPIO Mode - Host Transfer Flow        | 238 |
| 2-18.      | 8-Bit Parallel GetWord Function                | 239 |
| 2-19.      | SPI Loader                                     | 240 |
| 2-20.      | Data Transfer From EEPROM Flow                 | 242 |
| 2-21.      | Overview of SPIA_GetWordData Function          | 242 |
| 2-22.      | EEPROM Device at Address 0x50                  | 243 |
| 2-23.      | Overview of I2C_Boot Function                  | 244 |
| 2-24.      | Random Read                                    | 245 |
| 2-25.      | Sequential Read                                | 245 |



| 2-26. | Overview of eCAN-A bootloader Operation                                                                       | 246 |
|-------|---------------------------------------------------------------------------------------------------------------|-----|
| 2-27. | ExitBoot Procedure Flow                                                                                       | 248 |
| 2-28. | CLA Data ROM                                                                                                  | 254 |
| 2-29. | Secure ROM                                                                                                    | 256 |
| 3-1.  | Multiple ePWM Modules                                                                                         | 259 |
| 3-2.  | Submodules and Signal Connections for an ePWM Module                                                          | 260 |
| 3-3.  | ePWM Submodules and Critical Internal Signal Interconnects                                                    | 261 |
| 3-4.  | Time-Base Submodule Block Diagram                                                                             |     |
| 3-5.  | Time-Base Submodule Signals and Registers                                                                     | 267 |
| 3-6.  | Time-Base Frequency and Period                                                                                | 269 |
| 3-7.  | Time-Base Counter Synchronization Scheme 1                                                                    | 270 |
| 3-8.  | Time-Base Up-Count Mode Waveforms                                                                             | 272 |
| 3-9.  | Time-Base Down-Count Mode Waveforms                                                                           | 273 |
| 3-10. | Time-Base Up-Down-Count Waveforms, TBCTL[PHSDIR = 0] Count Down On Synchronization Event                      | 273 |
| 3-11. | Time-Base Up-Down Count Waveforms, TBCTL[PHSDIR = 1] Count Up On Synchronization Event                        | 274 |
| 3-12. | Counter-Compare Submodule                                                                                     | 274 |
| 3-13. | Detailed View of the Counter-Compare Submodule                                                                |     |
| 3-14. | Counter-Compare Event Waveforms in Up-Count Mode                                                              |     |
| 3-15. | Counter-Compare Events in Down-Count Mode                                                                     | 278 |
| 3-16. | Counter-Compare Events In Up-Down-Count Mode, TBCTL[PHSDIR = 0] Count Down On<br>Synchronization Event        | 279 |
| 3-17. | Counter-Compare Events In Up-Down-Count Mode, TBCTL[PHSDIR = 1] Count Up On Synchronization Event             | 279 |
| 3-18. | Action-Qualifier Submodule                                                                                    | 280 |
| 3-19. | Action-Qualifier Submodule Inputs and Outputs                                                                 | 281 |
| 3-20. | Possible Action-Qualifier Actions for EPWMxA and EPWMxB Outputs                                               | 282 |
| 3-21. | Up-Down-Count Mode Symmetrical Waveform                                                                       | 285 |
| 3-22. | Up, Single Edge Asymmetric Waveform, With Independent Modulation on EPWMxA and EPWMxB—Active High.            | 286 |
| 3-23. | Up, Single Edge Asymmetric Waveform With Independent Modulation on EPWMxA and EPWMxB—Active Low               | 287 |
| 3-24. | Up-Count, Pulse Placement Asymmetric Waveform With Independent Modulation on EPWMxA                           | 288 |
| 3-25. | Up-Down-Count, Dual Edge Symmetric Waveform, With Independent Modulation on EPWMxA and EPWMxB — Active Low    | 289 |
| 3-26. | Up-Down-Count, Dual Edge Symmetric Waveform, With Independent Modulation on EPWMxA and EPWMxB — Complementary | 291 |
| 3-27. | Up-Down-Count, Dual Edge Asymmetric Waveform, With Independent Modulation on EPWMxA—Active Low.               | 292 |
| 3-28. | Dead_Band Submodule                                                                                           | 293 |
| 3-29. | Configuration Options for the Dead-Band Submodule                                                             | 294 |
| 3-30. | Dead-Band Waveforms for Typical Cases (0% < Duty < 100%)                                                      | 296 |
| 3-31. | PWM-Chopper Submodule                                                                                         | 298 |
| 3-32. | PWM-Chopper Submodule Operational Details                                                                     | 299 |
| 3-33. | Simple PWM-Chopper Submodule Waveforms Showing Chopping Action Only                                           | 299 |
| 3-34. | PWM-Chopper Submodule Waveforms Showing the First Pulse and Subsequent Sustaining Pulses                      | 300 |
| 3-35. | PWM-Chopper Submodule Waveforms Showing the Pulse Width (Duty Cycle) Control of Sustaining Pulses             | 302 |
| 3-36. | Trip-Zone Submodule                                                                                           | 303 |
| 3-37. | Trip-Zone Submodule Mode Control Logic                                                                        | 307 |
| 3-38. | Trip-Zone Submodule Interrupt Logic                                                                           | 308 |
| 3-39. | Event-Trigger Submodule                                                                                       | 309 |
|       |                                                                                                               |     |

| www.ti.com |                                                                                                                 |     |  |  |
|------------|-----------------------------------------------------------------------------------------------------------------|-----|--|--|
| 3-40.      | Event-Trigger Submodule Inter-Connectivity of ADC Start of Conversion                                           | 309 |  |  |
| 3-41.      | Event-Trigger Submodule Showing Event Inputs and Prescaled Outputs                                              | 310 |  |  |
| 3-42.      | Event-Trigger Interrupt Generator                                                                               | 311 |  |  |
| 3-43.      | Event-Trigger SOCA Pulse Generator                                                                              | 312 |  |  |
| 3-44.      | Event-Trigger SOCB Pulse Generator                                                                              | 312 |  |  |
| 3-45.      | Digital-Compare Submodule High-Level Block Diagram                                                              | 313 |  |  |
| 3-46.      | DCAEVT1 Event Triggering                                                                                        | 315 |  |  |
| 3-47.      | DCAEVT2 Event Triggering                                                                                        | 315 |  |  |
| 3-48.      | DCBEVT1 Event Triggering                                                                                        | 316 |  |  |
| 3-49.      | DCBEVT2 Event Triggering                                                                                        | 316 |  |  |
| 3-50.      | Event Filtering                                                                                                 | 317 |  |  |
| 3-51.      | Blanking Window Timing Diagram                                                                                  | 318 |  |  |
| 3-52.      | Simplified ePWM Module                                                                                          | 319 |  |  |
| 3-53.      | EPWM1 Configured as a Typical Master, EPWM2 Configured as a Slave                                               | 320 |  |  |
| 3-54.      | Control of Four Buck Stages. Here F <sub>PWM1</sub> ≠ F <sub>PWM2</sub> ≠ F <sub>PWM3</sub> ≠ F <sub>PWM4</sub> | 321 |  |  |
| 3-55.      | Buck Waveforms for (Note: Only three bucks shown here)                                                          | 322 |  |  |
| 3-56.      | Control of Four Buck Stages. (Note: F <sub>PWM2</sub> = N x F <sub>PWM1</sub> )                                 | 324 |  |  |
| 3-57.      | Buck Waveforms for (Note: F <sub>PWM2</sub> = F <sub>PWM1</sub> )                                               | 325 |  |  |
| 3-58.      | Control of Two Half-H Bridge Stages (F <sub>PWM2</sub> = N x F <sub>PWM1</sub> )                                | 327 |  |  |
| 3-59.      | Half-H Bridge Waveforms for (Note: Here $F_{PWM2} = F_{PWM1}$ )                                                 | 328 |  |  |
| 3-60.      | Control of Dual 3-Phase Inverter Stages as Is Commonly Used in Motor Control                                    | 330 |  |  |
| 3-61.      | 3-Phase Inverter Waveforms for (Only One Inverter Shown)                                                        | 331 |  |  |
| 3-62.      | Configuring Two PWM Modules for Phase Control                                                                   | 333 |  |  |
| 3-63.      | Timing Waveforms Associated With Phase Control Between 2 Modules                                                | 334 |  |  |
| 3-64.      | Control of a 3-Phase Interleaved DC/DC Converter                                                                | 335 |  |  |
| 3-65.      | 3-Phase Interleaved DC/DC Converter Waveforms for                                                               | 336 |  |  |
| 3-66.      | Controlling a Full-H Bridge Stage (F <sub>PWM2</sub> = F <sub>PWM1</sub> )                                      | 338 |  |  |
| 3-67.      | ZVS Full-H Bridge Waveforms                                                                                     | 339 |  |  |
| 3-68.      | Peak Current Mode Control of a Buck Converter                                                                   | 341 |  |  |
| 3-69.      | Peak Current Mode Control Waveforms for                                                                         | 341 |  |  |
| 3-70.      | Time-Base Period Register (TBPRD)                                                                               | 343 |  |  |
| 3-71.      | Time-Base Phase Register (TBPHS)                                                                                | 343 |  |  |
| 3-72.      | Time-Base Counter Register (TBCTR)                                                                              | 343 |  |  |
| 3-73.      | Time-Base Control Register (TBCTL)                                                                              | 344 |  |  |
| 3-74.      | Time-Base Status Register (TBSTS)                                                                               | 346 |  |  |
| 3-75.      | Counter-Compare A Register (CMPA)                                                                               | 347 |  |  |
| 3-76.      | Counter-Compare B Register (CMPB)                                                                               | 347 |  |  |
| 3-77.      | Counter-Compare Control Register (CMPCTL)                                                                       | 349 |  |  |
| 3-78.      | Counter-Compare A Mirror Register (CMPAM)                                                                       | 349 |  |  |
| 3-79.      | Action-Qualifier Output A Control Register (AQCTLA)                                                             | 350 |  |  |
| 3-80.      | Action-Qualifier Output B Control Register (AQCTLB)                                                             | 351 |  |  |
| 3-81.      | Action-Qualifier Software Force Register (AQSFRC)                                                               | 352 |  |  |
| 3-82.      | Action-Qualifier Continuous Software Force Register (AQCSFRC)                                                   | 353 |  |  |
| 3-83.      | Dead-Band Generator Control Register (DBCTL)                                                                    | 355 |  |  |
| 3-84.      | Dead-Band Generator Rising Edge Delay Register (DBRED)                                                          | 356 |  |  |
| 3-85.      | Dead-Band Generator Falling Edge Delay Register (DBFED)                                                         | 356 |  |  |
| 3-86.      | PWM-Chopper Control Register (PCCTL)                                                                            | 357 |  |  |
| 3-87.      | Trip-Zone Select Register (TZSEL)                                                                               | 359 |  |  |
| 3-88.      | Trip-Zone Control Register (TZCTL)                                                                              | 360 |  |  |



| ww |  |  |
|----|--|--|
|    |  |  |
|    |  |  |
|    |  |  |

| 3-89.          | Trip-Zone Enable Interrupt Register (TZEINT)                                   | 361 |
|----------------|--------------------------------------------------------------------------------|-----|
| 3-90.          | Trip-Zone Flag Register (TZFLG)                                                | 362 |
| 3-91.          | Trip-Zone Clear Register (TZCLR)                                               | 363 |
| 3-92.          | Trip-Zone Force Register (TZFRC)                                               | 363 |
| 3-93.          | Trip Zone Digital Compare Event Select Register (TZDCSEL)                      | 364 |
| 3-94.          | Digital Compare Trip Select (DCTRIPSEL)                                        | 366 |
| 3-95.          | Digital Compare A Control Register (DCACTL)                                    | 367 |
| 3-96.          | Digital Compare B Control Register (DCBCTL)                                    | 368 |
| 3-97.          | Digital Compare Filter Control Register (DCFCTL)                               | 368 |
| 3-98.          | Digital Compare Capture Control Register (DCCAPCTL)                            | 369 |
| 3-99.          | Digital Compare Counter Capture Register (DCCAP)                               | 369 |
| 3-100.         | Digital Compare Filter Offset Register (DCFOFFSET)                             | 370 |
|                | Digital Compare Filter Offset Counter Register (DCFOFFSETCNT)                  | 370 |
|                | Digital Compare Filter Window Register (DCFWINDOW)                             | 371 |
|                | Digital Compare Filter Window Counter Register (DCFWINDOWCNT)                  | 371 |
|                | Event-Trigger Selection Register (ETSEL)                                       | 371 |
|                | Event-Trigger Prescale Register (ETPS)                                         | 373 |
|                | Event-Trigger Flag Register (ETFLG)                                            | 374 |
|                | Event-Trigger Clear Register (ETCLR)                                           | 375 |
|                | Event-Trigger Force Register (ETFRC)                                           | 375 |
| 4-1.           | Capture and APWM Modes of Operation                                            | 379 |
| 4-2.           | Counter Compare and PRD Effects on the eCAP Output in APWM Mode                | 380 |
| 4-3.           | Capture Function Diagram                                                       | 381 |
| 4-4.           | Event Prescale Control                                                         | 382 |
| 4-5.           | Prescale Function Waveforms                                                    | 382 |
| 4-6.           | Details of the Continuous/One-shot Block                                       | 383 |
| 4-7.           | Details of the Counter and Synchronization Block                               | 384 |
| 4-8.           | Interrupts in eCAP Module                                                      | 385 |
| 4-9.           | PWM Waveform Details Of APWM Mode Operation                                    | 386 |
| 4-9.<br>4-10.  | Time-Stamp Counter Register (TSCTR)                                            | 387 |
| 4-10.<br>4-11. | Counter Phase Control Register (CTRPHS)                                        | 387 |
| 4-11.<br>4-12. | Capture-1 Register (CAP1)                                                      |     |
|                |                                                                                | 387 |
| 4-13.          | Capture-2 Register (CAP2)                                                      | 387 |
| 4-14.          | Capture-3 Register (CAP3)                                                      | 388 |
| 4-15.          | Capture-4 Register (CAP4)                                                      | 388 |
| 4-16.          | ECAP Control Register 1 (ECCTL1)                                               | 388 |
| 4-17.          | ECAP Control Register 2 (ECCTL2)                                               | 389 |
| 4-18.          | ECAP Interrupt Enable Register (ECEINT)                                        | 392 |
| 4-19.          | ECAP Interrupt Flag Register (ECFLG)                                           | 393 |
| 4-20.          | ECAP Interrupt Clear Register (ECCLR)                                          | 393 |
| 4-21.          | ECAP Interrupt Forcing Register (ECFRC)                                        | 394 |
| 4-22.          | Capture Sequence for Absolute Time-stamp and Rising Edge Detect                | 397 |
| 4-23.          | Capture Sequence for Absolute Time-stamp With Rising and Falling Edge Detect   | 399 |
| 4-24.          | Capture Sequence for Delta Mode Time-stamp and Rising Edge Detect              | 401 |
| 4-25.          | Capture Sequence for Delta Mode Time-stamp With Rising and Falling Edge Detect | 403 |
| 4-26.          | PWM Waveform Details of APWM Mode Operation                                    | 405 |
| 5-1.           | Optical Encoder Disk                                                           | 408 |
| 5-2.           | QEP Encoder Output Signal for Forward/Reverse Movement                         | 408 |
| 5-3.           | Index Pulse Example                                                            | 409 |



| www.ti.co | www.ti.com                                                                               |     |  |  |  |
|-----------|------------------------------------------------------------------------------------------|-----|--|--|--|
| 5-        | I. Functional Block Diagram of the eQEP Peripheral                                       | 411 |  |  |  |
| 5-        | 5. Functional Block Diagram of Decoder Unit                                              | 413 |  |  |  |
| 5-        | 6. Quadrature Decoder State Machine                                                      | 414 |  |  |  |
| 5-        | 7. Quadrature-clock and Direction Decoding                                               | 415 |  |  |  |
| 5-        | B. Position Counter Reset by Index Pulse for 1000 Line Encoder (QPOSMAX = 3999 or 0xF9F) | 417 |  |  |  |
| 5-        | Position Counter Underflow/Overflow (QPOSMAX = 4)                                        | 418 |  |  |  |
| 5-        | 0. Software Index Marker for 1000-line Encoder (QEPCTL[IEL] = 1)                         | 420 |  |  |  |
| 5-        | 1. Strobe Event Latch (QEPCTL[SEL] = 1)                                                  | 420 |  |  |  |
| 5-        | 2. eQEP Position-compare Unit                                                            | 421 |  |  |  |
| 5-        | 3. eQEP Position-compare Event Generation Points                                         | 422 |  |  |  |
| 5-        | 4. eQEP Position-compare Sync Output Pulse Stretcher                                     | 422 |  |  |  |
| 5-        | 5. eQEP Edge Capture Unit                                                                | 424 |  |  |  |
| 5-        | 6. Unit Position Event for Low Speed Measurement (QCAPCTL[UPPS] = 0010)                  | 424 |  |  |  |
| 5-        | 7. eQEP Edge Capture Unit - Timing Details                                               | 425 |  |  |  |
| 5-        | 8. eQEP Watchdog Timer                                                                   | 426 |  |  |  |
| 5-        | 9. eQEP Unit Time Base                                                                   | 426 |  |  |  |
| 5-        | 20. EQEP Interrupt Generation                                                            | 427 |  |  |  |
| 5-        | 21. QEP Decoder Control (QDECCTL) Register                                               | 427 |  |  |  |
| 5-        | 22. eQEP Control (QEPCTL) Register                                                       | 428 |  |  |  |
| 5-        | 23. eQEP Position-compare Control (QPOSCTL) Register                                     | 430 |  |  |  |
| 5-        | 24. eQEP Capture Control (QCAPCTL) Register                                              | 431 |  |  |  |
| 5-        | 25. eQEP Position Counter (QPOSCNT) Register                                             | 431 |  |  |  |
| 5-        | 26. eQEP Position Counter Initialization (QPOSINIT) Register                             | 431 |  |  |  |
| 5-        | 27. eQEP Maximum Position Count Register (QPOSMAX) Register                              | 432 |  |  |  |
| 5-        | 28. eQEP Position-compare (QPOSCMP) Register                                             | 432 |  |  |  |
| 5-        | 29. eQEP Index Position Latch (QPOSILAT) Register                                        | 432 |  |  |  |
| 5-        | 30. eQEP Strobe Position Latch (QPOSSLAT) Register                                       | 432 |  |  |  |
| 5-        | 31. eQEP Position Counter Latch (QPOSLAT) Register                                       | 433 |  |  |  |
| 5-        | 32. eQEP Unit Timer (QUTMR) Register                                                     | 433 |  |  |  |
| 5-        | 33. eQEP Register Unit Period (QUPRD) Register                                           |     |  |  |  |
| 5-        | 34. eQEP Watchdog Timer (QWDTMR) Register                                                |     |  |  |  |
| 5-        | 35. eQEP Watchdog Period (QWDPRD) Register                                               | 434 |  |  |  |
| 5-        | 36. eQEP Interrupt Enable (QEINT) Register                                               | 434 |  |  |  |
| 5-        | 37. eQEP Interrupt Flag (QFLG) Register                                                  | 435 |  |  |  |
| 5-        | 38. eQEP Interrupt Clear (QCLR) Register                                                 | 436 |  |  |  |
| 5-        | 39. eQEP Interrupt Force (QFRC) Register                                                 | 437 |  |  |  |
| 5-        |                                                                                          | 438 |  |  |  |
| 5-        |                                                                                          | 439 |  |  |  |
|           | 2. eQEP Capture Period (QCPRD) Register                                                  | 439 |  |  |  |
| 5-        |                                                                                          | 439 |  |  |  |
| 5-        |                                                                                          | 440 |  |  |  |
| 6-        | 5                                                                                        | 443 |  |  |  |
| 6-        | 5                                                                                        | 444 |  |  |  |
| 6-        |                                                                                          | 446 |  |  |  |
| 6-        | 5                                                                                        | 447 |  |  |  |
| 6-        |                                                                                          | 448 |  |  |  |
| 6-        |                                                                                          | 449 |  |  |  |
| 6-        | •                                                                                        | 451 |  |  |  |
| 6-        | 3. ADC Control Register 1 (ADCCTL1) (Address Offset 00h)                                 | 454 |  |  |  |



| 6-9.          | ADC Control Register 2 (ADCCTL2) (Address Offset 01h)                              | 456 |
|---------------|------------------------------------------------------------------------------------|-----|
| 6-10.         | ADC Interrupt Flag Register (ADCINTFLG) (Address Offset 04h)                       | 457 |
| 6-11.         | ADC Interrupt Flag Clear Register (ADCINTFLGCLR) (Address Offset 05h)              | 457 |
| 6-12.         | ADC Interrupt Overflow Register (ADCINTOVF) (Address Offset 06h)                   | 458 |
| 6-13.         | ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) (Address Offset 07h)          | 458 |
| 6-14.         | Interrupt Select 1 And 2 Register (INTSEL1N2) (Address Offset 08h)                 | 459 |
| 6-15.         | Interrupt Select 3 And 4 Register (INTSEL3N4) (Address Offset 09h)                 | 459 |
| 6-16.         | Interrupt Select 5 And 6 Register (INTSEL5N6) (Address Offset 0Ah)                 | 459 |
| 6-17.         | Interrupt Select 7 And 8 Register (INTSEL7N8) (Address Offset 0Bh)                 | 459 |
| 6-18.         | Interrupt Select 9 And 10 Register (INTSEL9N10) (Address Offset 0Ch)               | 460 |
| 6-19.         | ADC Start of Conversion Priority Control Register (SOCPRICTL)                      | 461 |
| 6-20.         | ADC Sample Mode Register (ADCSAMPLEMODE) (Address Offset 12h)                      | 463 |
| 6-21.         | ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) (Address Offset 14h)   | 464 |
| 6-22.         | ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) (Address Offset 15h)   | 465 |
| 6-23.         | ADC SOC Flag 1 Register (ADCSOCFLG1) (Address Offset 18h)                          | 465 |
| 6-24.         | ADC SOC Force 1 Register (ADCSOCFRC1) (Address Offset 1Ah)                         | 465 |
| 6-25.         | ADC SOC Overflow 1 Register (ADCSOCOVF1) (Address Offset 1Ch)                      | 466 |
| 6-26.         | ADC SOC Overflow Clear 1 Register (ADCSOCOVFCLR1) (Address Offset 1Eh)             | 466 |
| 6-27.         | ADC SOC0 - SOC15 Control Registers (ADCSOCxCTL) (Address Offset 20h - 2Fh)         | 467 |
| 6-28.         | ADC Reference/Gain Trim Register (ADCREFTRIM) (Address Offset 40h)                 | 469 |
| 6-29.         | ADC Offset Trim Register (ADCOFFTRIM) (Address Offset 41h)                         | 469 |
| 6-30.         | ADC Revision Register (ADCREV) (Address Offset 4Fh)                                | 469 |
| 6-31.         | ADC RESULT0 - RESULT15 Registers (ADCRESULTx) (PF1 Block Address Offset 00h - 0Fh) | 470 |
| 6-32.         | Timing Example For Sequential Mode / Late Interrupt Pulse                          | 470 |
| 6-33.         | Timing Example For Sequential Mode / Early Interrupt Pulse                         | 471 |
| 6-34.         | Timing Example For Simultaneous Mode / Late Interrupt Pulse                        | 472 |
| 6-35.         | Timing Example For Simultaneous Mode / Early Interrupt Pulse                       | 473 |
| 6-36.         | Timing Example for NONOVERLAP Mode                                                 | 473 |
| 6-37.         | Temperature Sensor Transfer Function                                               | 474 |
| 7-1.          | PGA Signals                                                                        | 477 |
| 7-2.          | PGA Model                                                                          | 477 |
| 7-3.          | VREFOUT Model                                                                      | 478 |
| 7-4.          | Voltage Comparator                                                                 | 478 |
| 7-5.          | Comparator Block Diagram                                                           | 479 |
| 7-6.          | PGA-Only Example                                                                   | 479 |
| 7-7.          | Signal Amplification                                                               | 479 |
| 7-8.          | Digital Filter Behavior                                                            | 480 |
| 7-9.          | Comparator and DFSS Block Diagram                                                  | 481 |
| 7-10.         | M1 Comparator Subsystem Block Diagram                                              | 482 |
| 7-11.         | PFC Comparator Subsystem Block Diagram                                             | 482 |
| 7-12.         | Digital Filter Subsystem Block Diagram                                             | 483 |
| 7-13.         | CTRIP Output Subsystem Block Diagram                                               | 483 |
| 7-14.         | AFE and ADC Block Diagram                                                          | 484 |
| 7-15.         | DAC1-DAC5 Control Register (DACxCTL)                                               | 485 |
| 7-16.         | VREF Output Control Register (VREFOUTCTL)                                          | 486 |
| 7-17.<br>7 19 | DAC Enable Register (DACEN)                                                        | 487 |
| 7-18.<br>7 10 | VREF Out Enable Register (VREFOUTEN)                                               | 488 |
| 7-19.<br>7-20 | PGA Enable Register (PGAEN)                                                        | 489 |
| 7-20.         | Comparator Enable Register (COMPEN)                                                | 490 |

| www.ti.com                |                                                                                 |            |
|---------------------------|---------------------------------------------------------------------------------|------------|
| 7-21.                     | M1 Amplifier Gain Control Register (AMPM1_GAIN)                                 | 491        |
| 7-22.                     | M2 Amplifier Gain Control Register (AMPM2_GAIN)                                 | 492        |
| 7-23.                     | PFC Amplifier Gain Control Register (AMP_PFC_GAIN)                              | 493        |
| 7-24.                     | ADC Input Switch Control Register (ADCINSWITCH)                                 | 494        |
| 7-25.                     | Comparator Hysteresis Control Register (COMPHYSTCTL)                            | 495        |
| 7-26.                     | CTRIP A1, A3, B1 Filter Input and Function Control Registers (CTRIPxxICTL)      | 497        |
| 7-27.                     | CTRIP B7 Filter Input and Function Control Register (CTRIPB7ICTL)               | 498        |
| 7-28.                     | CTRIP A1, A3, B1, B7 Filter Parameter Control Registers (CTRIPxxFILCTL)         | 499        |
| 7-29.                     | CTRIP A1, A3, B1, B7 Filter Sample Clock Control Registers (CTRIPxxFILCLKCTL)   | 499        |
| 7-30.                     | CTRIP M1 Filter Output Control Registers (CTRIPM10CTL)                          | 500        |
| 7-31.                     |                                                                                 |            |
| 7-32.                     | CTRIP M1 Filter Output Flag Clear Registers (CTRIPM1FLGCLR)                     | 502        |
| 7-33.                     | CTRIP PFC Filter Output Control Register (CTRIPPFCOCTL)                         | 503        |
| 7-34.                     |                                                                                 |            |
| 7-35.                     |                                                                                 | 505        |
| 7-36.                     | 5                                                                               | 506        |
| 7-37.                     |                                                                                 |            |
| 7-38.                     |                                                                                 |            |
| 7-39.                     | 5                                                                               | 509        |
| 8-1.                      | CLA Block Diagram                                                               |            |
| 8-2.                      | Task Interrupt Vector (MVECT1/2/3/4/5/6/7/8) Register                           | 521        |
| 8-3.                      | Control Register (MCTL)                                                         | 522        |
| 8-4.                      | Memory Configuration Register (MMEMCFG)                                         |            |
| 8-5.                      | CLA Peripheral Interrupt Source Select 1 Register (MPISRCSEL1)                  |            |
| 8-6.                      | Interrupt Enable Register (MIER)                                                | 527        |
| 8-7.                      | Interrupt Flag Register (MIFR)                                                  | 528        |
| 8-8.                      | Interrupt Overflow Flag Register (MIOVF)                                        | 529        |
| 8-9.                      | Interrupt Run Status Register (MIRUN)                                           | 530        |
| 8-10.                     |                                                                                 |            |
| 8-11.                     |                                                                                 |            |
| 8-12.                     |                                                                                 |            |
| 8-13.<br>8-14             |                                                                                 | 534        |
| 8-14.                     |                                                                                 | 534        |
| 9-1.<br>9-2.              | Multiple I2C Modules Connected         I2C Module Conceptual Block Diagram      | 660<br>662 |
| 9-2.<br>9-3.              | Clocking Diagram for the I2C Module                                             | 663        |
| 9-3.<br>9-4.              | Bit Transfer on the I2C-Bus.                                                    | 664        |
| 9- <del>4</del> .<br>9-5. | I2C Module START and STOP Conditions                                            | 665        |
| 9-6.                      | I2C Module Data Transfer (7-Bit Addressing with 8-bit Data Configuration Shown) | 665        |
| 9-7.                      | I2C Module 7-Bit Addressing Format (FDF = 0, XA = 0 in I2CMDR)                  | 666        |
| 9-8.                      | I2C Module 10-Bit Addressing Format (FDF = 0, XA = 1 in I2CMDR)                 | 666        |
| 9-9.                      | I2C Module Free Data Format (FDF = 1 in I2CMDR)                                 | 666        |
| 9-10.                     |                                                                                 | 667        |
| 9-11.                     | · · · · · · · · · · · · · · · · · · ·                                           | 668        |
| 9-12.                     | · · · · · · · · · · · · · · · · · · ·                                           | 668        |
| 9-13.                     |                                                                                 | 670        |
| 9-14.                     |                                                                                 | 672        |
| 9-15.                     |                                                                                 | 675        |
| 9-16.                     |                                                                                 | 675        |
|                           |                                                                                 |            |



|        | www.t                                                                                                                                          | i.com |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 9-17.  | BCM Bit, Slave Transmitter Mode                                                                                                                | 676   |
| 9-18.  | I2C Interrupt Enable Register (I2CIER)                                                                                                         | 677   |
| 9-19.  | I2C Status Register (I2CSTR)                                                                                                                   | 678   |
| 9-20.  | I2C Interrupt Source Register (I2CISRC)                                                                                                        | 681   |
| 9-21.  | I2C Prescaler Register (I2CPSC)                                                                                                                | 681   |
| 9-22.  | The Roles of the Clock Divide-Down Values (ICCL and ICCH)                                                                                      | 682   |
| 9-23.  | I2C Clock Low-Time Divider Register (I2CCLKL)                                                                                                  | 682   |
| 9-24.  | I2C Clock High-Time Divider Register (I2CCLKH)                                                                                                 | 682   |
| 9-25.  | I2C Slave Address Register (I2CSAR)                                                                                                            | 683   |
| 9-26.  | I2C Own Address Register (I2COAR)                                                                                                              | 684   |
| 9-27.  | I2C Data Count Register (I2CCNT)                                                                                                               | 684   |
| 9-28.  | I2C Data Receive Register (I2CDRR)                                                                                                             | 685   |
| 9-29.  | I2C Data Transmit Register (I2CDXR)                                                                                                            | 685   |
| 9-30.  | I2C Transmit FIFO Register (I2CFFTX)                                                                                                           | 685   |
| 9-31.  | I2C Receive FIFO Register (I2CFFRX)                                                                                                            | 686   |
| 10-1.  | SPI CPU Interface                                                                                                                              | 689   |
| 10-2.  | Serial Peripheral Interface Module Block Diagram                                                                                               | 691   |
| 10-3.  | SPI Master/Slave Connection                                                                                                                    | 694   |
| 10-4.  | SPICLK Signal Options                                                                                                                          | 698   |
| 10-5.  | SPI: SPICLK-CLKOUT Characteristic When (BRR + 1) is Odd, BRR > 3, and CLOCK POLARITY = 1                                                       | 698   |
| 10-6.  | Five Bits per Character                                                                                                                        | 700   |
| 10-7.  | SPI FIFO Interrupt Flags and Enable Logic Generation                                                                                           | 701   |
| 10-8.  | SPI 3-wire Master Mode                                                                                                                         | 702   |
| 10-9.  | SPI 3-wire Slave Mode                                                                                                                          | 703   |
| 10-10. | SPI Configuration Control Register (SPICCR) — Address 7040h                                                                                    | 705   |
| 10-11. | SPI Operation Control Register (SPICTL) — Address 7041h                                                                                        | 706   |
| 10-12. | SPI Status Register (SPIST) — Address 7042h                                                                                                    | 707   |
| 10-13. | SPI Baud Rate Register (SPIBRR) — Address 7044h                                                                                                | 708   |
| 10-14. | SPI Emulation Buffer Register (SPIRXEMU) — Address 7046h                                                                                       | 709   |
| 10-15. | SPI Serial Receive Buffer Register (SPIRXBUF) — Address 7047h                                                                                  | 709   |
| 10-16. | SPI Serial Transmit Buffer Register (SPITXBUF) — Address 7048h                                                                                 | 710   |
| 10-17. | SPI Serial Data Register (SPIDAT) — Address 7049h                                                                                              | 710   |
| 10-18. | SPI FIFO Transmit (SPIFFTX) Register - Address 704Ah                                                                                           | 711   |
| 10-19. | SPI FIFO Receive (SPIFFRX) Register - Address 704Bh                                                                                            | 711   |
| 10-20. | SPI FIFO Control (SPIFFCT) Register - Address 704Ch                                                                                            | 712   |
| 10-21. | SPI Priority Control Register (SPIPRI) — Address 704Fh                                                                                         | 713   |
| 10-22. | CLOCK POLARITY = 0, CLOCK PHASE = 0 (All data transitions are during the rising edge, non-delayed                                              |       |
|        | clock. Inactive level is low.)                                                                                                                 | 714   |
| 10-23. | CLOCK POLARITY = 0, CLOCK PHASE = 1 (All data transitions are during the rising edge, but delayed by half clock cycle. Inactive level is low.) | 715   |
| 10.24  | CLOCK POLARITY = 1, CLOCK PHASE = 0 (All data transitions are during the falling edge. Inactive                                                | 115   |
| 10-24. | level is high.)                                                                                                                                | 715   |
| 10-25. | CLOCK POLARITY = 1, CLOCK PHASE = 1 (All data transitions are during the falling edge, but delayed                                             |       |
|        | by half clock cycle. Inactive level is high.)                                                                                                  | 716   |
| 10-26. | SPISTE Behavior in Master Mode (Master lowers SPISTE during the entire 16 bits of transmission.)                                               | 716   |
| 10-27. | SPISTE Behavior in Slave Mode (Slave's SPISTE is lowered during the entire 16 bits of transmission.)                                           | 717   |
| 11-1.  | SCI CPU Interface                                                                                                                              | 719   |
| 11-2.  | Serial Communications Interface (SCI) Module Block Diagram                                                                                     | 720   |
| 11-3.  | Typical SCI Data Frame Formats                                                                                                                 | 722   |
| 11-4.  | Idle-Line Multiprocessor Communication Format                                                                                                  | 723   |

| www.ti.com |                                                             |     |
|------------|-------------------------------------------------------------|-----|
| 11-5.      | Double-Buffered WUT and TXSHF                               | 724 |
| 11-6.      | Address-Bit Multiprocessor Communication Format             | 725 |
| 11-7.      | SCI Asynchronous Communications Format                      | 726 |
| 11-8.      | SCI RX Signals in Communication Modes                       | 726 |
| 11-9.      | SCI TX Signals in Communications Mode                       | 727 |
| 11-10.     | SCI FIFO Interrupt Flags and Enable Logic                   | 730 |
| 11-11.     | SCI Communication Control Register (SCICCR) — Address 7050h | 734 |
| 11-12.     | SCI Control Register 1 (SCICTL1) — Address 7051h            | 735 |
| 11-13.     | Baud-Select MSbyte Register (SCIHBAUD) — Address 7052h      | 737 |
| 11-14.     | Baud-Select LSbyte Register (SCILBAUD) — Address 7053h      | 737 |
| 11-15.     | SCI Control Register 2 (SCICTL2) — Address 7054h            | 738 |
| 11-16.     | SCI Receiver Status Register (SCIRXST) — Address 7055h      | 738 |
| 11-17.     | Register SCIRXST Bit Associations — Address 7055h           | 740 |
| 11-18.     | Emulation Data Buffer Register (SCIRXEMU) — Address 7056h   | 740 |
| 11-19.     | SCI Receive Data Buffer Register (SCIRXBUF) — Address 7057h | 740 |
| 11-20.     | Transmit Data Buffer Register (SCITXBUF) — Address 7059h    | 741 |
| 11-21.     | SCI FIFO Transmit (SCIFFTX) Register — Address 705Ah        | 741 |
| 11-22.     | SCI FIFO Receive (SCIFFRX) Register — Address 705Bh         | 742 |
| 11-23.     | SCI FIFO Control (SCIFFCT) Register — Address 705Ch         | 743 |
| 11-24.     | SCI Priority Control Register (SCIPRI) — Address 705Fh      | 745 |
| 12-1.      | eCAN Block Diagram and Interface Circuit                    | 748 |
| 12-2.      | CAN Data Frame                                              | 749 |
| 12-3.      | Architecture of the eCAN Module                             | 750 |
| 12-4.      | eCAN-A Memory Map                                           | 753 |
| 12-5.      | Mailbox-Enable Register (CANME)                             | 759 |
| 12-6.      | Mailbox-Direction Register (CANMD)                          | 760 |
| 12-7.      | Transmission-Request Set Register (CANTRS)                  | 761 |
| 12-8.      | Transmission-Request-Reset Register (CANTRR)                | 762 |
| 12-9.      | Transmission-Acknowledge Register (CANTA)                   | 763 |
|            |                                                             | 764 |
|            |                                                             | 765 |
|            | Received-Message-Lost Register (CANRML)                     | 766 |
|            | Remote-Frame-Pending Register (CANRFP)                      | 767 |
|            | Global Acceptance Mask Register (CANGAM)                    | 769 |
|            | Master Control Register (CANMC)                             | 770 |
|            | Bit-Timing Configuration Register (CANBTC)                  | 773 |
|            | Error and Status Register (CANES)                           | 775 |
|            | Transmit-Error-Counter Register (CANTEC)                    | 777 |
|            | Receive-Error-Counter Register (CANREC)                     | 777 |
|            | Global Interrupt Flag 0 Register (CANGIF0)                  | 779 |
|            | Global Interrupt Flag 1 Register (CANGIF1)                  | 779 |
|            | Global Interrupt Mask Register (CANGIM)                     | 781 |
|            | Mailbox Interrupt Mask Register (CANMIM)                    | 783 |
|            | Mailbox Interrupt Level Register (CANMIL)                   | 784 |
|            | Overwrite Protection Control Register (CANOPC)              | 785 |
|            | TX I/O Control Register (CANTIOC)                           | 786 |
|            | RX I/O Control Register (CANRIOC)                           | 787 |
|            | Time-Stamp Counter Register (CANTSC)                        | 789 |
| 12-29.     | Message Object Time Stamp Registers (MOTS)                  | 790 |



| 12-30. | Message-Object Time-Out Registers (MOTO)         | 791 |
|--------|--------------------------------------------------|-----|
| 12-31. | Time-Out Control Register (CANTOC)               | 792 |
| 12-32. | Time-Out Status Register (CANTOS)                | 793 |
| 12-33. | Message Identifier Register (MSGID) Register     | 794 |
| 12-34. | Message-Control Register (MSGCTRL)               | 796 |
| 12-35. | Message-Data-Low Register With DBO = 0 (CANMDL)  | 797 |
| 12-36. | Message-Data-High Register With DBO = 0 (CANMDH) | 797 |
| 12-37. | Message-Data-Low Register With DBO = 1 (CANMDL)  | 797 |
| 12-38. | Message-Data-High Register With DBO = 1 (CANMDH) | 797 |
| 12-39. | Local-Acceptance-Mask Register (LAMn)            | 799 |
| 12-40. | Initialization Sequence                          | 800 |
|        | CAN Bit Timing                                   |     |
| 12-42. | Interrupts Scheme                                | 807 |



# List of Tables

| 1-1.  | Flash/OTP Configuration Registers                                              | 39 |
|-------|--------------------------------------------------------------------------------|----|
| 1-2.  | Flash Options Register (FOPT) Field Descriptions                               | 40 |
| 1-3.  | Flash Power Register (FPWR) Field Descriptions                                 | 40 |
| 1-4.  | Flash Status Register (FSTATUS) Field Descriptions                             | 41 |
| 1-5.  | Flash Standby Wait Register (FSTDBYWAIT) Field Descriptions                    | 42 |
| 1-6.  | Flash Standby to Active Wait Counter Register (FACTIVEWAIT) Field Descriptions | 42 |
| 1-7.  | Flash Wait-State Register (FBANKWAIT) Field Descriptions                       | 43 |
| 1-8.  | OTP Wait-State Register (FOTPWAIT) Field Descriptions                          | 44 |
| 1-9.  | PLL, Clocking, Watchdog, and Low-Power Mode Registers                          | 46 |
| 1-10. | Peripheral Clock Control 0 Register (PCLKCR0) Field Descriptions               | 46 |
| 1-11. | Peripheral Clock Control 1 Register (PCLKCR1) Field Descriptions               | 48 |
| 1-12. | Peripheral Clock Control 3 Register (PCLKCR3) Field Descriptions               | 49 |
| 1-13. | Peripheral Clock Control 4 Register (PCLKCR4) Field Descriptions               | 50 |
| 1-14. | Low-Speed Peripheral Clock Prescaler Register (LOSPCP) Field Descriptions      | 51 |
| 1-15. | Internal Oscillator n Trim (INTOSCnTRIM) Register Field Descriptions           | 53 |
| 1-16. | Clocking (XCLK) Field Descriptions                                             | 54 |
| 1-17. | Clock Control (CLKCTL) Register Field Descriptions                             | 54 |
| 1-18. | Possible PLL Configuration Modes                                               | 57 |
| 1-19. | NMI Interrupt Registers                                                        | 61 |
| 1-20. | NMI Configuration (NMICFG) Register Bit Definitions (EALLOW)                   | 61 |
| 1-21. | NMI Flag (NMIFLG) Register Bit Definitions (EALLOW Protected):                 |    |
| 1-22. | NMI Flag Clear (NMIFLGCLR) Register Bit Definitions (EALLOW Protected)         | 62 |
| 1-23. | NMI Flag Force (NMIFLGFRC) Register Bit Definitions (EALLOW Protected):        | 62 |
| 1-24. | NMI Watchdog Counter (NMIWDCNT) Register Bit Definitions                       |    |
| 1-25. | NMI Watchdog Period (NMIWDPRD) Register Bit Definitions (EALLOW Protected      | 63 |
| 1-26. | PLL Settings                                                                   | 66 |
| 1-27. | PLL Status Register (PLLSTS) Field Descriptions                                | 66 |
| 1-28. | PLL Lock Period (PLLLOCKPRD) Register Field Descriptions                       | 68 |
| 1-29. | Low-Power Mode Summary                                                         | 69 |
| 1-30. | Low Power Modes                                                                | 69 |
| 1-31. | Low Power Mode Control 0 Register (LPMCR0) Field Descriptions                  | 70 |
| 1-32. | Example Watchdog Key Sequences                                                 | 73 |
| 1-33. | System Control and Status Register (SCSR) Field Descriptions                   | 75 |
| 1-34. | Watchdog Counter Register (WDCNTR) Field Descriptions                          | 76 |
| 1-35. | Watchdog Reset Key Register (WDKEY) Field Descriptions                         | 76 |
| 1-36. | Watchdog Control Register (WDCR) Field Descriptions                            | 76 |
| 1-37. | CPU-Timers 0, 1, 2 Configuration and Control Registers                         | 79 |
| 1-38. | TIMERxTIM Register Field Descriptions                                          | 79 |
| 1-39. | TIMERxTIMH Register Field Descriptions                                         | 80 |
| 1-40. | TIMERxPRD Register Field Descriptions                                          | 80 |
| 1-41. | TIMERxPRDH Register Field Descriptions                                         | 80 |
| 1-42. | TIMERxTCR Register Field Descriptions                                          | 80 |
| 1-43. | TIMERxTPR Register Field Descriptions                                          | 81 |
| 1-44. | TIMERxTPRH Register Field Descriptions                                         | 82 |
| 1-45. | GPIO Control Registers                                                         | 87 |
| 1-46. | GPIO Interrupt and Low Power Mode Select Registers                             | 87 |
| 1-47. | GPIO Data Registers                                                            | 89 |
|       |                                                                                |    |



| Ŵ |  |  |
|---|--|--|
|   |  |  |
|   |  |  |
|   |  |  |

| 1-48. | Sampling Period                                                            | 92  |
|-------|----------------------------------------------------------------------------|-----|
| 1-49. | Sampling Frequency                                                         | 92  |
| 1-50. | Case 1: Three-Sample Sampling Window Width                                 | 93  |
| 1-51. | Case 2: Six-Sample Sampling Window Width                                   | 93  |
| 1-52. | Default State of Peripheral Input                                          | 96  |
| 1-53. | 2805x GPIOA MUX                                                            | 97  |
| 1-54. | 2805x GPIOB MUX                                                            | 98  |
| 1-55. | GPIO Port A Multiplexing 1 (GPAMUX1) Register Field Descriptions           | 99  |
| 1-56. | GPIO Port A MUX 2 (GPAMUX2) Register Field Descriptions                    | 101 |
| 1-57. | GPIO Port B MUX 1 (GPBMUX1) Register Field Descriptions                    | 103 |
| 1-58. | GPIO Port A Qualification Control (GPACTRL) Register Field Descriptions    | 105 |
| 1-59. | GPIO Port B Qualification Control (GPBCTRL) Register Field Descriptions    | 106 |
| 1-60. | GPIO Port A Qualification Select 1 (GPAQSEL1) Register Field Descriptions  | 107 |
| 1-61. | GPIO Port A Qualification Select 2 (GPAQSEL2) Register Field Descriptions  | 107 |
| 1-62. | GPIO Port B Qualification Select 1 (GPBQSEL1) Register Field Descriptions  | 108 |
| 1-63. | GPIO Port A Direction (GPADIR) Register Field Descriptions                 | 108 |
| 1-64. | GPIO Port B Direction (GPBDIR) Register Field Descriptions                 | 109 |
| 1-65. | GPIO Port A Internal Pullup Disable (GPAPUD) Register Field Descriptions   | 109 |
| 1-66. | GPIO Port B Internal Pullup Disable (GPBPUD) Register Field Descriptions   | 110 |
| 1-67. | GPIO Port A Data (GPADAT) Register Field Descriptions                      | 111 |
| 1-68. | GPIO Port B Data (GPBDAT) Register Field Descriptions                      | 111 |
| 1-69. | GPIO Port A Set (GPASET) Register Field Descriptions                       | 112 |
| 1-70. | GPIO Port A Clear (GPACLEAR) Register Field Descriptions                   | 112 |
| 1-71. | GPIO Port A Toggle (GPATOGGLE) Register Field Descriptions                 | 112 |
| 1-72. | GPIO Port B Set (GPBSET) Register Field Descriptions                       | 113 |
| 1-73. | GPIO Port B Clear (GPBCLEAR) Register Field Descriptions                   | 113 |
| 1-74. | GPIO Port B Toggle (GPBTOGGLE) Register Field Descriptions                 | 113 |
| 1-75. | GPIO XINTn Interrupt Select (GPIOXINTnSEL) Register Field Descriptions     | 113 |
| 1-76. | XINT1/XINT2/XINT3 Interrupt Select and Configuration Registers             | 114 |
| 1-77. | GPIO Low Power Mode Wakeup Select (GPIOLPMSEL) Register Field Descriptions | 114 |
| 1-78. | Peripheral Frame 0 Registers                                               | 115 |
| 1-79. | Peripheral Frame 1 Registers                                               | 116 |
| 1-80. | Peripheral Frame 2 Registers                                               | 116 |
| 1-81. | Access to EALLOW-Protected Registers                                       | 117 |
| 1-82. | EALLOW-Protected Device Emulation Registers                                | 117 |
| 1-83. | EALLOW-Protected Flash/OTP Configuration Registers                         | 117 |
| 1-84. | EALLOW-Protected Code Security Module (DCSM) Registers (Zone 1)            | 118 |
| 1-85. | EALLOW-Protected Code Security Module (DCSM) Registers (Zone 2)            | 118 |
| 1-86. | EALLOW-Protected PLL, Clocking, Watchdog, and Low-Power Mode Registers     | 118 |
| 1-87. | EALLOW-Protected GPIO Registers                                            | 120 |
| 1-88. | EALLOW-Protected PIE Vector Table                                          | 121 |
| 1-89. | EALLOW-Protected ePWM1 - ePWM 7 Registers                                  | 121 |
| 1-90. | Device Emulation Registers                                                 | 122 |
| 1-91. | DEVICECNF Register Field Descriptions                                      | 122 |
| 1-92. | PARTID Register Field Descriptions                                         | 123 |
| 1-93. | REVID Register Field Descriptions                                          | 123 |
| 1-94. | Enabling Interrupt                                                         | 127 |
| 1-95. | Interrupt Vector Table Mapping                                             | 128 |
| 1-96. | Vector Table Mapping After Reset Operation                                 | 128 |

| www.ti.com |                                                                                    |     |
|------------|------------------------------------------------------------------------------------|-----|
| 1-97.      | PIE MUXed Peripheral Interrupt Vector Table                                        | 134 |
| 1-98.      | PIE Vector Table                                                                   | 135 |
| 1-99.      | PIE Configuration and Control Registers                                            | 139 |
| 1-100.     | PIECTRL Register Address Field Descriptions                                        | 140 |
| 1-101.     | PIE Interrupt Acknowledge Register (PIEACK) Field Descriptions                     | 140 |
| 1-102.     | PIEIFRx Register Field Descriptions                                                | 141 |
| 1-103.     | PIEIERx Register (x = 1 to 12) Field Descriptions                                  | 142 |
| 1-104.     | Interrupt Flag Register (IFR) — CPU Register Field Descriptions                    | 143 |
| 1-105.     | Interrupt Enable Register (IER) — CPU Register Field Descriptions                  | 145 |
| 1-106.     | Debug Interrupt Enable Register (DBGIER) — CPU Register Field Descriptions         | 146 |
| 1-107.     | Interrupt Control and Counter Registers (not EALLOW Protected)                     | 148 |
| 1-108.     | External Interrupt <i>n</i> Control Register (XINT <i>n</i> CR) Field Descriptions | 148 |
| 1-109.     | External Interrupt n Counter (XINTnCTR) Field Descriptions                         | 149 |
| 1-110.     | BOR Configuration (BORCFG) Field Descriptions                                      | 151 |
| 1-111.     | RAM Status                                                                         | 152 |
| 1-112.     | Security Levels                                                                    | 152 |
| 1-113.     | Location of Zone-Select Block Based on Link-Pointer                                | 156 |
| 1-114.     | DCSM_OTP_Z1 DCSM REGISTERS                                                         | 165 |
| 1-115.     | Z1_LINKPOINTER Register Field Descriptions                                         | 166 |
| 1-116.     | Z1_OTPSECLOCK Register Field Descriptions                                          | 167 |
| 1-117.     | Z1_BOOTMODE Register Field Descriptions                                            | 168 |
| 1-118.     | DCSM_OTP_Z2 DCSM REGISTERS                                                         | 168 |
| 1-119.     | Z2_LINKPOINTER Register Field Descriptions                                         | 169 |
| 1-120.     | Z2_OTPSECLOCK Register Field Descriptions                                          | 170 |
| 1-121.     | Z2_BOOTMODE Register Field Descriptions                                            | 171 |
| 1-122.     | DCSM_REGS_COMMON DCSM REGISTERS                                                    | 171 |
| 1-123.     | FLSEM Register Field Descriptions                                                  | 172 |
| 1-124.     | SECTSTAT Register Field Descriptions                                               | 173 |
| 1-125.     | RAMSTAT Register Field Descriptions                                                | 175 |
| 1-126.     | DCSM_REGS_Z1 DCSM REGISTERS                                                        | 176 |
| 1-127.     | Z1_LINKPOINTER Register Field Descriptions                                         | 177 |
| 1-128.     | Z1_OTPSECLOCK Register Field Descriptions                                          | 178 |
| 1-129.     | Z1_BOOTMODE Register Field Descriptions                                            | 179 |
| 1-130.     | Z1_CSMKEY0 Register Field Descriptions                                             | 180 |
| 1-131.     | Z1_CSMKEY1 Register Field Descriptions                                             | 181 |
| 1-132.     | Z1_CSMKEY2 Register Field Descriptions                                             | 182 |
| 1-133.     | Z1_CSMKEY3 Register Field Descriptions                                             | 183 |
| 1-134.     | Z1_CR Register Field Descriptions                                                  | 184 |
| 1-135.     | Z1_GRABSECTR Register Field Descriptions                                           | 185 |
| 1-136.     | Z1_GRABRAMR Register Field Descriptions                                            | 187 |
| 1-137.     | Z1_EXEONLYSECTR Register Field Descriptions                                        | 188 |
| 1-138.     | Z1_EXEONLYRAMR Register Field Descriptions                                         | 190 |
| 1-139.     | DCSM_REGS_Z2 DCSM REGISTERS                                                        | 191 |
|            | Z2_LINKPOINTER Register Field Descriptions                                         | 192 |
|            | Z2_OTPSECLOCK Register Field Descriptions                                          | 193 |
| 1-142.     | Z2_BOOTMODE Register Field Descriptions                                            | 194 |
|            | Z2_CSMKEY0 Register Field Descriptions                                             | 195 |
|            | Z2_CSMKEY1 Register Field Descriptions                                             | 196 |
| 1-145.     | Z2_CSMKEY2 Register Field Descriptions                                             | 197 |



| www |  |  |
|-----|--|--|
|     |  |  |

| 1-146. | Z2_CSMKEY3 Register Field Descriptions                             | 198 |
|--------|--------------------------------------------------------------------|-----|
| 1-147. | Z2_CR Register Field Descriptions                                  | 199 |
| 1-148. | Z2_GRABSECTR Register Field Descriptions                           | 200 |
| 1-149. | Z2_GRABRAMR Register Field Descriptions                            | 202 |
| 1-150. | Z2_EXEONLYSECTR Register Field Descriptions                        | 203 |
| 1-151. | Z2_EXEONLYRAMR Register Field Descriptions                         | 205 |
| 2-1.   | Vector Locations                                                   | 211 |
| 2-2.   | Configuration for Device Modes                                     | 214 |
| 2-3.   | PIE Vector SARAM Locations Used by the Boot ROM                    | 216 |
| 2-4.   | Boot Mode Selection                                                | 216 |
| 2-5.   | Valid EMU_KEY and EMU_BMODE Values                                 | 218 |
| 2-6.   | OTP Values for GetMode                                             | 220 |
| 2-7.   | Zx-BOOTMODE Register Bit Definition                                | 221 |
| 2-8.   | Emulation Boot modes (TRST = 1)                                    | 221 |
| 2-9.   | Stand-Alone Boot Modes with (TRST = 0)                             | 222 |
| 2-10.  | General Structure Of Source Program Data Stream In 16-Bit Mode     | 225 |
| 2-11.  | LSB/MSB Loading Sequence in 8-Bit Data Stream                      | 227 |
| 2-12.  | Parallel GPIO Boot 8-Bit Data Stream                               |     |
| 2-13.  | SPI 8-Bit Data Stream                                              | 240 |
| 2-14.  | I2C 8-Bit Data Stream                                              | 245 |
| 2-15.  | Bit-Rate Value for Internal Oscillators                            | 246 |
| 2-16.  | eCAN 8-Bit Data Stream                                             | 247 |
| 2-17.  | CPU Register Restored Values                                       | 249 |
| 2-18.  | Bootloader Options                                                 | 250 |
| 2-19.  | Bootloader Revision and Checksum Information                       | 253 |
| 2-20.  | Bootloader Revision Per Device                                     | 253 |
| 2-21.  | ROM API Entry point                                                | 253 |
| 2-22.  |                                                                    | 255 |
| 3-1.   | ePWM Module Control and Status Register Set Grouped by Submodule   |     |
| 3-2.   | Submodule Configuration Parameters                                 | 264 |
| 3-3.   | Time-Base Submodule Registers                                      | 267 |
| 3-4.   | Key Time-Base Signals                                              | 267 |
| 3-5.   | Counter-Compare Submodule Registers                                | 275 |
| 3-6.   | Counter-Compare Submodule Key Signals                              | 276 |
| 3-7.   | Action-Qualifier Submodule Registers                               | 280 |
| 3-8.   | Action-Qualifier Submodule Possible Input Events                   | 281 |
| 3-9.   | Action-Qualifier Event Priority for Up-Down-Count Mode             | 283 |
| 3-10.  | Action-Qualifier Event Priority for Up-Count Mode                  | 283 |
| 3-11.  | Action-Qualifier Event Priority for Down-Count Mode                | 283 |
| 3-12.  | Behavior if CMPA/CMPB is Greater than the Period.                  | 283 |
| 3-13.  | Dead-Band Generator Submodule Registers                            | 293 |
| 3-14.  | Classical Dead-Band Operating Modes                                | 295 |
| 3-15.  | Dead-Band Delay Values in $\mu$ S as a Function of DBFED and DBRED | 297 |
| 3-16.  | PWM-Chopper Submodule Registers                                    | 298 |
| 3-17.  | Possible Pulse Width Values for SYSCLKOUT = 100 MHz                | 300 |
| 3-18.  | Trip-Zone Submodule Registers                                      | 304 |
| 3-19.  | Possible Actions On a Trip Event                                   | 306 |
| 3-20.  | Event-Trigger Submodule Registers                                  | 310 |
| 3-21.  | Digital Compare Submodule Registers                                | 313 |
|        |                                                                    |     |



| www.ti.com     |                                                                                  |            |
|----------------|----------------------------------------------------------------------------------|------------|
| 3-22.          | Time-Base Period Register (TBPRD) Field Descriptions                             | 343        |
| 3-23.          | Time-Base Phase Register (TBPHS) Field Descriptions                              | 343        |
| 3-24.          | Time-Base Counter Register (TBCTR) Field Descriptions                            | 343        |
| 3-25.          | Time-Base Control Register (TBCTL) Field Descriptions                            | 344        |
| 3-26.          | Time-Base Status Register (TBSTS) Field Descriptions                             | 346        |
| 3-27.          | Counter-Compare A Register (CMPA) Field Descriptions                             | 347        |
| 3-28.          | Counter-Compare B Register (CMPB) Field Descriptions                             | 348        |
| 3-29.          | Counter-Compare Control Register (CMPCTL) Field Descriptions                     | 349        |
| 3-30.          | Counter-Compare A Mirror Register (CMPAM) Field Descriptions                     | 350        |
| 3-31.          | Action-Qualifier Output A Control Register (AQCTLA) Field Descriptions           | 350        |
| 3-32.          | Action-Qualifier Output B Control Register (AQCTLB) Field Descriptions           | 351        |
| 3-33.          | Action-Qualifier Software Force Register (AQSFRC) Field Descriptions             | 352        |
| 3-34.          | Action-qualifier Continuous Software Force Register (AQCSFRC) Field Descriptions | 353        |
| 3-35.          | Dead-Band Generator Control Register (DBCTL) Field Descriptions                  | 355        |
| 3-36.          | Dead-Band Generator Rising Edge Delay Register (DBRED) Field Descriptions        | 356        |
| 3-37.          | Dead-Band Generator Falling Edge Delay Register (DBFED) Field Descriptions       | 356        |
| 3-38.          | PWM-Chopper Control Register (PCCTL) Bit Descriptions                            | 357        |
| 3-39.          | Trip-Zone Submodule Select Register (TZSEL) Field Descriptions                   | 359        |
| 3-40.          | Trip-Zone Control Register Field Descriptions                                    | 360        |
| 3-41.          | Trip-Zone Enable Interrupt Register (TZEINT) Field Descriptions                  | 361        |
| 3-42.          | Trip-Zone Flag Register Field Descriptions                                       | 362        |
| 3-43.          | Trip-Zone Clear Register (TZCLR) Field Descriptions                              | 363        |
| 3-44.          | Trip-Zone Force Register (TZFRC) Field Descriptions                              | 363        |
| 3-45.          | Trip Zone Digital Compare Event Select Register (TZDCSEL) Field Descriptions     | 364        |
| 3-46.          | Digital Compare Trip Select (DCTRIPSEL) Field Descriptions                       | 366        |
| 3-47.          | Digital Compare A Control Register (DCACTL) Field Descriptions                   | 367        |
| 3-48.          | Digital Compare B Control Register (DCBCTL) Field Descriptions                   | 368        |
| 3-49.          | Digital Compare Filter Control Register (DCFCTL) Field Descriptions              | 368        |
| 3-50.          | Digital Compare Capture Control Register (DCCAPCTL) Field Descriptions           |            |
| 3-51.          | Digital Compare Counter Capture Register (DCCAP) Field Descriptions              |            |
| 3-52.          | Digital Compare Filter Offset Register (DCFOFFSET) Field Descriptions            |            |
| 3-53.          | Digital Compare Filter Offset Counter Register (DCFOFFSETCNT) Field Descriptions |            |
| 3-54.          | Digital Compare Filter Window Register (DCFWINDOW) Field Descriptions            | 371        |
| 3-55.          | Digital Compare Filter Window Counter Register (DCFWINDOWCNT) Field Descriptions | 371        |
| 3-56.<br>2.57  | Event-Trigger Selection Register (ETSEL) Field Descriptions                      | 372        |
| 3-57.<br>3-58. | Event-Trigger Prescale Register (ETPS) Field Descriptions                        | 373        |
| 3-58.<br>3-59. | Event-Trigger Clear Register (ETCLR) Field Descriptions                          | 374<br>375 |
| 3-59.<br>3-60. | Event-Trigger Force Register (ETFRC) Field Descriptions                          | 375        |
| 3-00.<br>4-1.  | Time-Stamp Counter Register (TSCTR) Field Descriptions                           | 387        |
| 4-2.           | Counter Phase Control Register (CTRPHS) Field Descriptions                       | 387        |
| 4-3.           | Capture-1 Register (CAP1) Field Descriptions                                     | 387        |
| 4-4.           | Capture 2 Register (CAP2) Field Descriptions                                     | 387        |
| 4-5.           | Capture-3 Register (CAP3) Field Descriptions                                     | 388        |
| 4-6.           | Capture 4 Register (CAP4) Field Descriptions                                     | 388        |
| 4-7.           | ECAP Control Register 1 (ECCTL1) Field Descriptions                              | 388        |
| 4-8.           | ECAP Control Register 2 (ECCTL2) Field Descriptions                              | 390        |
| 4-9.           | ECAP Interrupt Enable Register (ECEINT) Field Descriptions                       | 392        |
| 4-10.          | ECAP Interrupt Flag Register (ECFLG) Field Descriptions                          | 393        |
|                |                                                                                  |            |



| www. |  |
|------|--|
|      |  |
|      |  |

| 4-12.       ECAP Interrupt Forcing Register (ECFRC) Field Descriptions       3         4-13.       Control and Status Register Set       3         5-1.       EQEP Memory Map       4         5-2.       Quadrature Decoder Truth Table       4         5-3.       eQEP Decoder Control (QDECCT.) Register Field Descriptions       4         5-4.       eQEP Control (QEPCTL) Register Field Descriptions       4         5-5.       eQEP Position Counter (QPOSCNT) Register Field Descriptions       4         5-6.       eQEP Position Counter Initialization (QPOSINT) Register Field Descriptions       4         5-7.       eQEP Position Counter Initialization (QPOSINT) Register Field Descriptions       4         5-8.       eQEP Position Counter Initialization (QPOSINT) Register Field Descriptions       4         5-10.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-11.       eQEP Index Position Latch (QPOSLAT) Register Field Descriptions       4         5-12.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions       4         5-15.       eQEP Matchdog Priod (QWDPRD) Register Field Descriptions       4         5-16.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4 <th></th> <th></th> <th></th>                                    |       |                                                                     |     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------------------------------------------------------|-----|
| 4-13.       Control and Status Register Set       5         5-2.       Cuadrature Decoder Truth Table       5         5-2.       Cuadrature Decoder Truth Table       5         5-3.       eQEP Decoder Control (QDECCTL) Register Field Descriptions       5         5-4.       eQEP Control (QCPCTL) Register Field Descriptions       5         5-5.       eQEP Position -compare Control (QPOSCTL) Register Field Descriptions       5         5-6.       eQEP Position Counter (QPOSCNT) Register Field Descriptions       5         5-7.       eQEP Position Counter (QPOSCMP) Register Field Descriptions       5         5-8.       eQEP Position Counter (QPOSCMP) Register Field Descriptions       5         5-9.       eQEP Position Counter Initialization (QPOSINT) Register Field Descriptions       5         5-10.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       5         5-11.       eQEP Index Position Latch (QPOSLAT) Register Field Descriptions       5         5-12.       eQEP Strobe Position Latch (QPOSLAT) Register Field Descriptions       5         5-13.       eQEP Unit Timer (QUTMR) Register Field Descriptions       5         5-14.       eQEP Watchdog Timer (QWDTR) Register Field Descriptions       5         5-15.       eQEP Natchdog Period (QWDPRD) Register Field Descriptions       5                                                                       | 4-11. |                                                                     | 394 |
| 5-1.       EQEP Memory Map       4         5-2.       Quadrature Decoder Truth Table       4         5-3.       eQEP Control (QDECCTL) Register Field Descriptions       4         5-4.       eQEP Control (QCPCTL) Register Field Descriptions       4         5-5.       eQEP Position-compare Control (QPOSCTL) Register Field Descriptions       4         5-7.       eQEP Position Counter (QPOSCNT) Register Field Descriptions       4         5-8.       eQEP Position Counter Initialization (QPOSINIT) Register Field Descriptions       4         5-10.       eQEP Position Count (QPOSCMP) Register Field Descriptions       4         5-11.       eQEP Position Latch(QPOSLAT) Register Field Descriptions       4         5-12.       eQEP Position Latch(QPOSLAT) Register Field Descriptions       4         5-13.       eQEP Init Timer (QUTMR) Register Field Descriptions       4         5-14.       eQEP Init Period (QUPRD) Register Field Descriptions       4         5-15.       eQEP Init Period (QUDTMR) Register Field Descriptions       4         5-16.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-17.       eQEP Interrupt Flag (QFLC) Register Field Descriptions       4         5-18.       eQEP Interrupt Flag (QFLC) Register Field Descriptions       4         5-20. <td< td=""><td></td><td></td><td>394</td></td<>                                             |       |                                                                     | 394 |
| 5-2.       Quadrature Decoder Control (QDECCTL) Register Field Descriptions       4         5-3.       eQEP Control (QDECCTL) Register Field Descriptions       4         5-4.       eQEP Control (QCAPCTL) Register Field Descriptions       4         5-5.       eQEP Position-compare Control (QCOSCTL) Register Field Descriptions       4         5-6.       eQEP Position Counter (IQPOSCTL) Register Field Descriptions       4         5-7.       eQEP Position Counter Initialization (QPOSMX) Register Field Descriptions       4         5-8.       eQEP Position Counter Initialization (QPOSMAX) Register Field Descriptions       4         5-10.       eQEP Position Counter Latch(QPOSLAT) Register Field Descriptions       4         5-11.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-12.       eQEP Volti Timer (QUTMR) Register Field Descriptions       4         5-13.       eQEP Volti Timer (QUTMR) Register Field Descriptions       4         5-14.       eQEP Vatchdog Timer (QUTMR) Register Field Descriptions       4         5-15.       eQEP Interrupt Flable(QEINT) Register Field Descriptions       4         5-16.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-19.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Capture Tim                                           |       |                                                                     | 395 |
| 5-3.       eQEP Decoder Control (QDECCTL) Register Field Descriptions       4         5-4.       eQEP Control (QEPCTL) Register Field Descriptions       4         5-5.       eQEP Position-compare Control (QOPOSCTL) Register Field Descriptions       4         5-6.       eQEP Position Counter (QPOSCNT) Register Field Descriptions       4         5-7.       eQEP Position Counter (QPOSCNT) Register Field Descriptions       4         5-8.       eQEP Position Counter Initialization (QPOSINIT) Register Field Descriptions       4         5-9.       eQEP Maximum Position Count (QPOSINIT) Register Field Descriptions       4         5-10.       eQEP Position Counter Lath (QPOSILAT) Register Field Descriptions       4         5-11.       eQEP Position Latch (QPOSILAT) Register Field Descriptions       4         5-12.       eQEP Position Counter Lath (QPOSILAT) Register Field Descriptions       4         5-13.       eQEP Position Counter Lath (QPOSILAT) Register Field Descriptions       4         5-14.       eQEP Valthdog Timer (QWDTMR) Register Field Descriptions       4         5-15.       eQEP Interrupt Flag (QLUPRD) Register Field Descriptions       4         5-16.       eQEP Interrupt Flag (QELG) Register Field Descriptions       4         5-17.       eQEP Interrupt Flag (QELG) Register Field Descriptions       4         5-20. <td< td=""><td></td><td></td><td>412</td></td<> |       |                                                                     | 412 |
| 5-4.       eQEP Control (QEPCTL) Register Field Descriptions       4         5-5.       eQEP Position-compare Control (QCPOSCTL) Register Field Descriptions       4         5-7.       eQEP Position Counter (QPOSCNT) Register Field Descriptions       4         5-8.       eQEP Position Counter Initialization (QPOSINIT) Register Field Descriptions       4         5-9.       eQEP Position Counter Initialization (QPOSINIT) Register Field Descriptions       4         5-10.       eQEP Position-compare (QPOSCMP) Register Field Descriptions       4         5-11.       eQEP Position-compare (QPOSCMP) Register Field Descriptions       4         5-12.       eQEP Nosition Latch (QPOSILAT) Register Field Descriptions       4         5-13.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions       4         5-15.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions       4         5-16.       eQEP Interrupt Fiag (QELC) Register Field Descriptions       4         5-17.       eQEP Interrupt Fiag (QELC) Register Field Descriptions       4         5-18.       eQEP Interrupt Fiag (QELC) Register Field Descriptions       4         5-19.       eQEP Interrupt Fiag (QELC) Register Field Descriptions       4         5-20.       eQEP Capture T                                           |       |                                                                     | 414 |
| 5-5.       eQEP Position-compare Control (QPOSCTL) Register Field Descriptions       4         5-6.       eQEP Position Counter (QPOSCNT) Register Field Descriptions       4         5-7.       eQEP Position Counter Initialization (QPOSINIT) Register Field Descriptions       4         5-8.       eQEP Position Counter Initialization (QPOSINIT) Register Field Descriptions       4         5-9.       eQEP Maximum Position Count (QPOSINIT) Register Field Descriptions       4         5-10.       eQEP Position Compare (QPOSCMP) Register Field Descriptions       4         5-11.       eQEP Strobe Position Latch (QPOSILAT) Register Field Descriptions       4         5-12.       eQEP Position Counter Latch (QPOSILAT) Register Field Descriptions       4         5-13.       eQEP Position Counter Latch (QPOSILAT) Register Field Descriptions       4         5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions       4         5-15.       eQEP Matchdog Timer (QWDTMR) Register Field Descriptions       4         5-16.       eQEP Matchdog Period (QWDPR) Register Field Descriptions       4         5-17.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-18.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5                                  |       |                                                                     | 427 |
| 5-6.       eQEP Capture Control (QCAPCTL) Register Field Descriptions       4         5-7.       eQEP Position Counter (IQPOSCMT) Register Field Descriptions       4         5-8.       eQEP Position Counter Initialization (QPOSINIT) Register Field Descriptions       4         5-9.       eQEP Maximum Position Count (QPOSMAX) Register Field Descriptions       4         5-10.       eQEP Position-compare (QPOSCMP) Register Field Descriptions       4         5-11.       eQEP Index Position Latch (QPOSLAT) Register Field Descriptions       4         5-12.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-13.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions       4         5-15.       eQEP Watchdog Timer (QWDTNR) Register Field Descriptions       4         5-16.       eQEP Watchdog Period (QWDPRD) Register Field Descriptions       4         5-17.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-20.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-21.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-22.       eQEP                                            |       |                                                                     |     |
| 5-7.       eQEP Position Counter (QPOSCNT) Register Field Descriptions       4         5-8.       eQEP Position Count (QPOSMAX) Register Field Descriptions       4         5-9.       eQEP Maximum Position Count (QPOSMAX) Register Field Descriptions       4         5-10.       eQEP Position-compare (QPOSCMP) Register Field Descriptions       4         5-11.       eQEP Nosition Latch (QPOSLAT) Register Field Descriptions       4         5-12.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-13.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-14.       eQEP Unit Priod (QUPRN) Register Field Descriptions       4         5-15.       eQEP Unit Priod (QUPRD) Register Field Descriptions       4         5-16.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions       4         5-17.       eQEP Naterrupt Enable(QEINT) Register Field Descriptions       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-20.       eQEP Interrupt Clear (QCLR) Register Field Descriptions       4         5-21.       eQEP Capture Period Register Field Descriptions       4         5-22.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-23.       eQEP Capture Period Register (QCPRD) Register Fie                                           |       |                                                                     | 430 |
| 5-8.       eQEP Position Counter Initialization (QPOSINIT) Register Field Descriptions       4         5-9.       eQEP Maximum Position Count (QPOSMAX) Register Field Descriptions       4         5-10.       eQEP Position-compare (QPOSCMP) Register Field Descriptions       4         5-11.       eQEP Index Position Latch (QPOSLAT) Register Field Descriptions       4         5-12.       eQEP Strobe Position Latch (QPOSLAT) Register Field Descriptions       4         5-13.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-14.       eQEP Unit Timer (QUTRR) Register Field Descriptions       4         5-15.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions       4         5-16.       eQEP Matchdog Timer (QWDTMR) Register Field Descriptions       4         5-17.       eQEP Matchdog Timer (QWDTMR) Register Field Descriptions       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-19.       eQEP Interrupt Clear (QCLR) Register Field Descriptions       4         5-20.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-21.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-22.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-23.       eQEP Ca                                           |       |                                                                     | 431 |
| 5-9.       eQEP Maximum Position Count (QPOSMAX) Register Field Descriptions       4         5-10.       eQEP Position-compare (QPOSCMP) Register Field Descriptions       4         5-11.       eQEP Index Position Latch (QPOSLAT) Register Field Descriptions       4         5-12.       eQEP Strobe Position Latch (QPOSLAT) Register Field Descriptions       4         5-13.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-14.       eQEP Unit Timer (QUTIR) Register Field Descriptions       4         5-15.       eQEP Unit Period (QUPRD) Register Field Descriptions       4         5-16.       eQEP Watchdog Timer (QWDTINR) Register Field Descriptions       4         5-17.       eQEP Pinterrupt Enable(CEINT) Register Field Descriptions       4         5-18.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-21.       eQEP Repture Timer (QCTMR) Register Field Descriptions       4         5-22.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-25.       eQEP Capture Period Register (ADCNTAT) Re                                           |       |                                                                     | 431 |
| 5-10.       eQEP Position-compare (QPOSCMP) Register Field Descriptions       4         5-11.       eQEP Index Position Latch (QPOSILAT) Register Field Descriptions.       4         5-12.       eQEP Position Latch (QPOSILAT) Register Field Descriptions.       4         5-13.       eQEP Position Counter Latch (QPOSILAT) Register Field Descriptions.       4         5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions.       4         5-15.       eQEP Unit Period (QUPD) Register Field Descriptions.       4         5-16.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions.       4         5-17.       eQEP Watchdog Period (QWDPRD) Register Field Descriptions.       4         5-19.       eQEP Interrupt Enable(QEINT) Register Field Descriptions.       4         5-20.       eQEP Interrupt Flag (QFLG) Register Field Descriptions.       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions.       4         5-22.       eQEP Capture Timer (QCTMR) Register Field Descriptions.       4         5-23.       eQEP Capture Register (QCPRD) Register Field Descriptions.       4         5-24.       eQEP Capture Period Latch (QCTMRLAT) Register Field Descriptions.       4         5-25.       eQEP Capture Period Latch (QCTMRLAT) Register Field Descriptions.       4         5-26.       eQE Capture Period                                            |       |                                                                     | 432 |
| 5-11.       eQEP Index Position Latch (QPOSILAT) Register Field Descriptions.       4         5-12.       eQEP Strobe Position Latch (QPOSLAT) Register Field Descriptions.       4         5-13.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions.       4         5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions.       4         5-15.       eQEP Watchdog Timer (QWDRD) Register Field Descriptions.       4         5-16.       eQEP Watchdog Timer (QWDPRD) Register Field Descriptions.       4         5-17.       eQEP Matchdog Timer (QUPRD) Register Field Descriptions.       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions.       4         5-19.       eQEP Interrupt Flag (QFLG) Register Field Descriptions.       4         5-20.       eQEP Interrupt Flag (QCLR) Register Field Descriptions.       4         5-21.       eQEP Interrupt Force (QCRR) Register Field Descriptions.       4         5-22.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Period Register (ADCNMLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period                                            |       |                                                                     | 432 |
| 5-12.       eQEP Strobe Position Latch (QPOSLAT) Register Field Descriptions       4         5-13.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions       4         5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions       4         5-15.       eQEP Unit Period (QUPRD) Register Field Descriptions       4         5-16.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions       4         5-17.       eQEP Watchdog Period (QWDPRD) Register Field Descriptions       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-19.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-23.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-24.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         5-25.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Control Register (ADCCTL1) Field Descript                                           |       |                                                                     | 432 |
| 5-13.       eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions.       4         5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions       4         5-15.       eQEP Unit Period (QUPD) Register Field Descriptions       4         5-16.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions       4         5-17.       eQEP Watchdog Period (QWDPRD) Register Field Descriptions       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-19.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Status (QEPSTS) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCTMLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Control Register (ADCCTL2) Field Descriptions <t< td=""><td></td><td></td><td>432</td></t<>           |       |                                                                     | 432 |
| 5-14.       eQEP Unit Timer (QUTMR) Register Field Descriptions       4         5-15.       eQEP Unit Period (QUPRD) Register Field Descriptions       4         5-16.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions       4         5-17.       eQEP Watchdog Period (QWDPRD) Register Field Descriptions       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-19.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Register (ADCINTFLG) Field Descriptions       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions <td></td> <td></td> <td>433</td>              |       |                                                                     | 433 |
| 5-15.       eQEP Unit Period (QUPRD) Register Field Descriptions.       4         5-16.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions       4         5-17.       eQEP Watchdog Period (QWDPRD) Register Field Descriptions       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-19.       eQEP Interrupt Enable(QERC) Register Field Descriptions       4         5-20.       eQEP Interrupt Clear (QCLR) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Status (QEPSTS) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-25.       eQEP Capture Timer Latch (QCPRD) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Register (ADCCNL) Field Descriptions       4         6-3.       ADC Control Register (ADCCNL) Field Descriptions       4         6-4.       ADC Control Register (ADCINTFLG) Field Descriptions       4     <                                                         |       |                                                                     | 433 |
| 5-16.       eQEP Watchdog Timer (QWDTMR) Register Field Descriptions       4         5-17.       eQEP Watchdog Period (QWDPRD) Register Field Descriptions       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-19.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-20.       eQEP Interrupt Clear (QCLR) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Status (QEPSTS) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-25.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-3.       ADC Control Register (ADCINTFLG) Field Descriptions       4         6-4.       ADC Control Register (ADCINTFLG) Field Descriptions       4         6-5.       ADC Interrupt Flag Clear Register (ADCINTOVF) Field Descriptions       4                                                          |       |                                                                     | 433 |
| 5-17.       eQEP Watchdog Period (QWDPRD) Register Field Description       4         5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-19.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Interrupt Clear (QCLR) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Status (QEPSTS) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-3.       ADC Control Register 7 (ADCTL2) Field Descriptions       4         6-4.       ADC Control Register (ADCINTFLG) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLGCLR) Field Descriptions       4         6-6.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions <td< td=""><td>5-15.</td><td></td><td></td></td<>        | 5-15. |                                                                     |     |
| 5-18.       eQEP Interrupt Enable(QEINT) Register Field Descriptions       4         5-19.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Interrupt Clear (QCLR) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register (ADCINTFLG) Field Descriptions       4         6-5.       ADC Interrupt Flag Clear Register (ADCINTOVF) Field Descriptions       4         6-6.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-7.       ADC Interrupt Overflow Clear Register (ADCINTOVF)                                            | 5-16. |                                                                     | 434 |
| 5-19.       eQEP Interrupt Flag (QFLG) Register Field Descriptions       4         5-20.       eQEP Interrupt Clear (QCLR) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Status (QEPSTS) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Period Latch (QCTMRLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         5-27.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register (ADCINTFLG) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-7.       ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Fi                                           |       |                                                                     | 434 |
| 5-20.       eQEP Interrupt Clear (QCLR) Register Field Descriptions       4         5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Status (QEPSTS) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Period Latch (QCTMRLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-7.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions </td <td>5-18.</td> <td></td> <td>434</td>  | 5-18. |                                                                     | 434 |
| 5-21.       eQEP Interrupt Force (QFRC) Register Field Descriptions       4         5-22.       eQEP Status (QEPSTS) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-7.       ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions <t< td=""><td>5-19.</td><td></td><td></td></t<>         | 5-19. |                                                                     |     |
| 5-22.       eQEP Status (QEPSTS) Register Field Descriptions       4         5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Timer Latch (QCTMRLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-7.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4                                                    | 5-20. |                                                                     | 436 |
| 5-23.       eQEP Capture Timer (QCTMR) Register Field Descriptions       4         5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Timer Latch (QCTMRLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Voerflow Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Regis                                           | 5-21. |                                                                     | 437 |
| 5-24.       eQEP Capture Period Register (QCPRD) Register Field Descriptions       4         5-25.       eQEP Capture Timer Latch (QCTMRLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4                                                                                              | 5-22. |                                                                     | 438 |
| 5-25.       eQEP Capture Timer Latch (QCTMRLAT) Register Field Descriptions       4         5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Voerflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                         | 5-23. |                                                                     | 439 |
| 5-26.       eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions       4         6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                               | 5-24. |                                                                     | 439 |
| 6-1.       Sample Timings with Different Values of ACQPS       4         6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                            | 5-25. |                                                                     | 440 |
| 6-2.       ADC Configuration & Control Registers (AdcRegs and AdcResult):       4         6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                     | 5-26. |                                                                     | 440 |
| 6-3.       ADC Control Register 1 (ADCCTL1) Field Descriptions       4         6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                               | 6-1.  |                                                                     | 445 |
| 6-4.       ADC Control Register 2 (ADCCTL2) Field Descriptions       4         6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 6-2.  |                                                                     | 454 |
| 6-5.       ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions       4         6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVF) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 6-3.  |                                                                     | 455 |
| 6-6.       ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions       4         6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 6-4.  |                                                                     | 457 |
| 6-7.       ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions       4         6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 6-5.  |                                                                     | 457 |
| 6-8.       ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Field Descriptions       4         6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 6-6.  | ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions | 458 |
| 6-9.       INTSELxNy Register Field Descriptions       4         6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 6-7.  |                                                                     | 458 |
| 6-10.       SOCPRICTL Register Field Descriptions       4         6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                                                     | 459 |
| 6-11.       ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions       4         6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions       4         6-13.       ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |                                                                     | 460 |
| 6-12.       ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |                                                                     | 462 |
| 6-13. ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                                                                     | 463 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 6-12. |                                                                     | 464 |
| 6-14. ADC SOC Flag 1 Register (ADCSOCFLG1) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 6-13. |                                                                     | 465 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 6-14. | ADC SOC Flag 1 Register (ADCSOCFLG1) Field Descriptions             | 465 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                                                                     | 466 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 6-16. |                                                                     | 466 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 6-17. |                                                                     | 466 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 6-18. |                                                                     | 467 |
| 6-19. ADC Reference/Gain Trim Register (ADCREFTRIM) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 6-19. |                                                                     | 469 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 6-20. | ADC Offset Trim Register (ADCOFFTRIM) Field Descriptions            | 469 |

| www.t | i.com          |                                                                                                                                  |            |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------|------------|
|       | 6-21.          | ADC Revision Register (ADCREV) Field Descriptions                                                                                | 469        |
|       | 6-22.          | ADC RESULT0 - ADCRESULT15 Registers (ADCRESULTx) Field Descriptions                                                              | 470        |
|       | 7-1.           | Comparator Truth Table                                                                                                           | 478        |
|       | 7-2.           | DAC Control Registers                                                                                                            | 485        |
|       | 7-3.           | DAC1-DAC5 Control Register (DACxCTL) Field Descriptions                                                                          | 485        |
|       | 7-4.           | VREF Output Control Register (VREFOUTCTL) Field Descriptions                                                                     | 486        |
|       | 7-5.           | DAC, PGA, Comparator, and Filter Enable Registers                                                                                | 487        |
|       | 7-6.           | DAC Enable Register (DACEN) Field Descriptions                                                                                   | 487        |
|       | 7-7.           | VREF Out Enable Register (VREFOUTEN) Field Descriptions                                                                          | 488        |
|       | 7-8.           | PGA Enable Register (PGAEN) Field Descriptions                                                                                   | 489        |
|       | 7-9.           | Comparator Enable Register (COMPEN) Field Descriptions                                                                           | 490        |
|       | 7-10.          | M1 Amplifier Gain Control Register (AMPM1_GAIN) Field Descriptions                                                               | 491        |
|       | 7-11.          | M2 Amplifier Gain Control Register (AMPM2_GAIN) Field Descriptions                                                               | 492        |
|       | 7-12.          | PFC Amplifier Gain Control Register (AMP_PFC_GAIN) Field Descriptions                                                            | 493        |
|       | 7-13.          | Switch Registers                                                                                                                 | 494        |
|       | 7-14.          | ADC Input Switch Control Register (ADCINSWITCH) Field Descriptions                                                               | 494        |
|       | 7-15.          | Comparator Hysteresis Control Register (COMPHYSTCTL) Field Descriptions                                                          | 495        |
|       | 7-16.          | Digital Filter and Comparator Control Registers                                                                                  | 496        |
|       | 7-17.          | CTRIP A1, A3, B1 Filter Input and Function Control Registers (CTRIPxxICTL) Field Descriptions                                    | 497        |
|       | 7-18.          | CTRIP B7 Filter Input and Function Control Register (CTRIPB7ICTL) Field Descriptions                                             | 498        |
|       | 7-19.          | CTRIP A1, A3, B1, B7 Filter Parameter Control Registers (CTRIPxxFILCTL) Field Descriptions                                       | 499        |
|       | 7-20.          | CTRIP A1, A3, B1, B7 Filter Parameter Control Registers (CTRIPxxFILCTL) Field Descriptions                                       | 499        |
|       | 7-21.          | CTRIP M1 Filter Output Control Registers (CTRIPM1OCTL) Field Descriptions                                                        | 500        |
|       | 7-22.          | CTRIP M1 Filter Output Status Registers (CTRIPM1STS) Field Descriptions                                                          | 501        |
|       | 7-23.          | CTRIP M1 Filter Output Flag Clear Registers (CTRIPM1FLGCLR) Field Descriptions                                                   | 502        |
|       | 7-24.          | CTRIP PFC Filter Output Control Register (CTRIPPFCOCTL) Field Descriptions                                                       | 503        |
|       | 7-25.          | CTRIP PFC Filter Output Status Register (CTRIPPFCSTS) Field Descriptions                                                         | 504        |
|       | 7-26.          | CTRIP PFC Filter Output Flag Clear Register (CTRIPPFCFLGCLR) Field Descriptions                                                  | 505        |
|       | 7-27.          |                                                                                                                                  | 506        |
|       | 7-28.          | Lock Register for CTRIP (LOCKCTRIP) Field Descriptions                                                                           |            |
|       | 7-29.          | Lock Register for DAC (LOCKDAC) Field Descriptions                                                                               |            |
|       | 7-30.          | Lock Register for Amplifiers and Comparators (LOCKAMPCOMP) Field Descriptions                                                    | 508        |
|       | 7-31.          | Lock Register for Switches (LOCKSWITCH) Field Descriptions                                                                       | 509        |
|       | 8-1.           | CLA Module Control and Status Register Set.                                                                                      | 520        |
|       | 8-2.           | Task Interrupt Vector (MVECT1/2/3/4/5/6/7/8) Field Descriptions                                                                  | 521        |
|       | 8-3.           | Control Register (MCTL) Field Descriptions                                                                                       | 523        |
|       | 8-4.           | Memory Configuration Register (MMEMCFG) Field Descriptions                                                                       | 524        |
|       | 8-5.           | Peripheral Interrupt Source Select 1 (MPISRCSEL1) Register Field Descriptions                                                    | 525        |
|       | 8-6.           | Interrupt Enable Register (MIER) Field Descriptions                                                                              | 527        |
|       | 8-7.           | Interrupt Flag Register (MIR) Field Descriptions                                                                                 | 528        |
|       | 8-8.           | Interrupt Overflow Flag Register (MIOVF) Field Descriptions                                                                      | 529        |
|       | 8-9.<br>8-10.  | Interrupt Run Status Register (MIRUN) Field Descriptions<br>Interrupt Force Register (MIFRC) Field Descriptions                  | 530<br>531 |
|       | 8-11.          |                                                                                                                                  |            |
|       | 8-11.<br>8-12. | Interrupt Flag Clear Register (MICLR) Field Descriptions<br>Interrupt Overflow Flag Clear Register (MICLROVF) Field Descriptions | 532<br>533 |
|       | 8-12.          | Program Counter (MPC) Field Descriptions                                                                                         | 533<br>534 |
|       | 8-13.<br>8-14. | CLA Status (MSTF) Register Field Descriptions                                                                                    | 535        |
|       | 8-15.          | Write Followed by Read - Read Occurs First                                                                                       | 538        |
|       | 8-16.          | Write Followed by Read - Write Occurs First                                                                                      | 538        |
|       | 0.10.          |                                                                                                                                  | 000        |

| 8-17.  | ADC to CLA Early Interrupt Response                                                     | 540               |
|--------|-----------------------------------------------------------------------------------------|-------------------|
| 8-18.  | Operand Nomenclature                                                                    | 542               |
| 8-19.  | INSTRUCTION dest, source1, source2 Short Description                                    | 543               |
| 8-20.  | Addressing Modes                                                                        | 544               |
| 8-21.  | Shift Field Encoding                                                                    | 544               |
| 8-22.  | Condition Field Encoding                                                                | 545               |
| 8-23.  | General Instructions                                                                    | 546               |
| 8-24.  | Pipeline Activity For MBCNDD, Branch Not Taken                                          | 561               |
| 8-25.  | Pipeline Activity For MBCNDD, Branch Taken                                              | 561               |
| 8-26.  | Pipeline Activity For MCCNDD, Call Not Taken                                            | 567               |
| 8-27.  | Pipeline Activity For MCCNDD, Call Taken                                                | 567               |
| 8-28.  | Pipeline Activity For MMOV16 MARx, MRa , #16I                                           | 599               |
| 8-29.  | Pipeline Activity For MMOV16 MAR0/MAR1, mem16                                           | <u>601</u>        |
| 8-30.  | Pipeline Activity For MMOVI16 MAR0/MAR1, #16I                                           | 614               |
| 8-31.  | Pipeline Activity For MRCNDD, Return Not Taken                                          | 636               |
| 8-32.  | Pipeline Activity For MRCNDD, Return Taken                                              | 636               |
| 8-33.  | Pipeline Activity For MSTOP                                                             | 640               |
| 9-1.   | Operating Modes of the I2C Module                                                       | 664               |
| 9-2.   | Ways to Generate a NACK Bit                                                             | 667               |
| 9-3.   | Descriptions of the Basic I2C Interrupt Requests                                        | 669               |
| 9-4.   | I2C Module Registers                                                                    | 670               |
| 9-5.   | I2C Mode Register (I2CMDR) Field Descriptions                                           | 672               |
| 9-6.   | Master-Transmitter/Receiver Bus Activity Defined by the RM, STT, and STP Bits of I2CMDR | 674               |
| 9-7.   | How the MST and FDF Bits of I2CMDR Affect the Role of the TRX Bit of I2CMDR             | 674               |
| 9-8.   | I2C Extended Mode Register (I2CEMDR) Field Descriptions                                 | 675               |
| 9-9.   | I2C Interrupt Enable Register (I2CIER) Field Descriptions                               | 677               |
| 9-10.  | I2C Status Register (I2CSTR) Field Descriptions                                         | 678               |
| 9-11.  | I2C Interrupt Source Register (I2CISRC) Field Descriptions                              | <mark>68</mark> 1 |
| 9-12.  | I2C Prescaler Register (I2CPSC) Field Descriptions                                      | 681               |
| 9-13.  | I2C Clock Low-Time Divider Register (I2CCLKL) Field Description                         | 682               |
| 9-14.  | I2C Clock High-Time Divider Register (I2CCLKH) Field Description                        | 682               |
| 9-15.  | Dependency of Delay d on the Divide-Down Value IPSC                                     | 683               |
| 9-16.  | I2C Slave Address Register (I2CSAR) Field Descriptions                                  | 683               |
| 9-17.  | I2C Own Address Register (I2COAR) Field Descriptions                                    | 684               |
| 9-18.  | I2C Data Count Register (I2CCNT) Field Descriptions                                     | 684               |
| 9-19.  | I2C Data Receive Register (I2CDRR) Field Descriptions                                   | 685               |
| 9-20.  | I2C Data Transmit Register (I2CDXR) Field Descriptions                                  | 685               |
| 9-21.  | I2C Transmit FIFO Register (I2CFFTX) Field Descriptions                                 | 686               |
| 9-22.  | I2C Receive FIFO Register (I2CFFRX) Field Descriptions                                  | 687               |
| 10-1.  | SPI Module Signal Summary                                                               | 692               |
| 10-2.  | SPI Registers                                                                           | 692               |
| 10-3.  | SPI Clocking Scheme Selection Guide                                                     | 698               |
| 10-4.  | SPI Interrupt Flag Modes                                                                | 702               |
| 10-5.  | 4-wire vs. 3-wire SPI Pin Functions                                                     | 702               |
| 10-6.  | 3-Wire SPI Pin Configuration                                                            | 703               |
| 10-7.  | SPI Configuration Control Register (SPICCR) Field Descriptions                          | 705               |
| 10-8.  | Character Length Control Bit Values                                                     | 706               |
| 10-9.  | SPI Operation Control Register (SPICTL) Field Descriptions                              | 706               |
| 10-10. | SPI Status Register (SPIST) Field Descriptions                                          | 707               |

| www.ti.com |                                                                      |     |
|------------|----------------------------------------------------------------------|-----|
| 10-11.     | Field Descriptions                                                   | 708 |
| 10-12.     | SPI Emulation Buffer Register (SPIRXEMU) Field Descriptions          | 709 |
| 10-13.     | SPI Serial Receive Buffer Register (SPIRXBUF) Field Descriptions     | 709 |
| 10-14.     | SPI Serial Transmit Buffer Register (SPITXBUF) Field Descriptions    | 710 |
| 10-15.     | SPI Serial Data Register (SPIDAT) Field Descriptions                 | 710 |
| 10-16.     | SPI FIFO Transmit (SPIFFTX) Register Field Descriptions              | 711 |
| 10-17.     | SPI FIFO Receive (SPIFFRX) Register Field Descriptions               | 712 |
| 10-18.     | SPI FIFO Control (SPIFFCT) Register Field Descriptions               | 712 |
| 10-19.     | SPI Priority Control Register (SPIPRI) Field Descriptions            | 713 |
| 11-1.      | SCI Module Signal Summary                                            | 721 |
| 11-2.      | Programming the Data Format Using SCICCR                             | 722 |
| 11-3.      | Asynchronous Baud Register Values for Common SCI Bit Rates           | 729 |
| 11-4.      | SCI Interrupt Flags                                                  | 730 |
| 11-5.      | SCI-A Registers                                                      | 732 |
| 11-6.      | SCI-B Registers                                                      | 732 |
| 11-7.      | SCIC Registers                                                       | 732 |
| 11-8.      | SCI Communication Control Register (SCICCR) Field Descriptions       | 734 |
| 11-9.      | SCI Control Register 1 (SCICTL1) Field Descriptions                  | 735 |
|            | Baud-Select Register Field Descriptions                              |     |
| 11-11.     | SCI Control Register 2 (SCICTL2) Field Descriptions                  | 738 |
| 11-12.     | SCI Receiver Status Register (SCIRXST) Field Descriptions            | 739 |
| 11-13.     | SCI Receive Data Buffer Register (SCIRXBUF) Field Descriptions       | 741 |
|            | Field Descriptions                                                   |     |
|            | SCI FIFO Receive (SCIFFRX) Register Field Descriptions               |     |
|            | SCI FIFO Control (SCIFFCT) Register Field Descriptions               |     |
| 11-17.     | Field Descriptions                                                   |     |
| 12-1.      | Register Map                                                         |     |
| 12-2.      | eCAN-A Mailbox RAM Layout                                            |     |
| 12-3.      | Addresses of LAM, MOTS and MOTO registers for mailboxes (eCAN-A)     |     |
| 12-4.      | Message Object Behavior Configuration                                |     |
| 12-5.      | Mailbox-Enable Register (CANME) Field Descriptions                   |     |
| 12-6.      | Mailbox-Direction Register (CANMD) Field Descriptions                | 760 |
| 12-7.      | Transmission-Request Set Register (CANTRS) Field Descriptions        | 761 |
| 12-8.      | Transmission-Request-Reset Register (CANTRR) Field Descriptions      | 762 |
| 12-9.      | Transmission-Acknowledge Register (CANTA) Field Descriptions         | 763 |
|            | Abort-Acknowledge Register (CANAA) Field Descriptions                | 764 |
|            | Received-Message-Pending Register (CANRMP) Field Descriptions        | 765 |
|            | Received-Message-Lost Register (CANRML) Field Descriptions           | 766 |
|            | Remote-Frame-Pending Register (CANRFP) Field Descriptions            | 767 |
|            | Global Acceptance Mask Register (CANGAM) Field Descriptions          | 769 |
|            | Master Control Register (CANMC) Field Descriptions                   | 770 |
|            | Bit-Timing Configuration Register (CANBTC) Field Descriptions        | 773 |
|            | Error and Status Register (CANES) Field Descriptions                 | 775 |
|            | Global Interrupt Flag Registers (CANGIF0/CANGIF1) Field Descriptions | 779 |
|            | Global Interrupt Mask Register (CANGIM) Field Descriptions           | 781 |
|            | Mailbox Interrupt Mask Register (CANMIM) Field Descriptions          | 783 |
|            | Mailbox Interrupt Level Register (CANMIL) Field Descriptions         | 784 |
|            | Overwrite Protection Control Register (CANOPC) Field Descriptions    | 785 |
| 12-23.     | TX I/O Control Register (CANTIOC) Field Descriptions                 | 786 |



| 12-24. | RX I/O Control Register (CANRIOC) Field Descriptions                                                         | 787 |
|--------|--------------------------------------------------------------------------------------------------------------|-----|
| 12-25. | Time-Stamp Counter Register (CANTSC) Field Descriptions                                                      | 789 |
| 12-26. | Message Object Time Stamp Registers (MOTS) Field Descriptions                                                | 790 |
| 12-27. | Message-Object Time-Out Registers (MOTO) Field Descriptions                                                  | 791 |
| 12-28. | Time-Out Control Register (CANTOC) Field Descriptions                                                        | 792 |
| 12-29. | Time-Out Status Register (CANTOS) Field Descriptions                                                         | 793 |
| 12-30. | Message Identifier Register (MSGID) Field Descriptions                                                       | 794 |
| 12-31. | Message-Control Register (MSGCTRL) Field Descriptions                                                        | 796 |
| 12-32. | Local-Acceptance-Mask Register (LAMn) Field Descriptions                                                     | 799 |
| 12-33. | BRP Field for Bit Rates (BT = 15, TSEG1 <sub>reg</sub> = 10, TSEG2 <sub>reg</sub> = 2, Sampling Point = 80%) | 802 |
| 12-34. | Achieving Different Sampling Points With a BT of 15                                                          | 802 |
| 12-35. | BRP Field for Bit Rates (BT = 10, TSEG1 <sub>reg</sub> = 6, TSEG2 <sub>reg</sub> = 1, Sampling Point = 80%)  | 802 |
| 12-36. | eCAN Interrupt Assertion/Clearing                                                                            | 809 |
| A-1.   | Revisions for this TRM                                                                                       | 813 |



# **Read This First**

# About This Manual

This Technical Reference Manual (TRM) details the integration, the environment, the functional description, and the programming models for each peripheral and subsystem in the device.

This TRM has been designated *Preliminary* because the documentation is in the formative or design phase of development. Texas Instruments reserves the right to change this TRM without notice. Visit the Texas Instruments website at <a href="http://www.ti.com">http://www.ti.com</a> to determine the latest version of this TRM.

# **Notational Conventions**

These documents use the following conventions.

• Hexadecimal numbers are shown with the suffix h. For example, the following number is 40 hexadecimal (decimal 64): 40h.

# **Related Documentation From Texas Instruments**

For a complete listing of related documentation and development-support tools for the TMS320x2805x Piccolo devices, visit the Texas Instruments website at <a href="http://www.ti.com">http://www.ti.com</a>. Additionally, the TMS320C28x CPU and Instruction Set Reference Guide (SPRU430) and TMS320C28x Floating Point Unit and Instruction Set Reference Guide (SPRUEO2) must be used in conjunction with this TRM.

The following books describe the related support tools that are available on the TI website:

# CPU User's Guides—

SPRU430 — TMS320C28x CPU and Instruction Set Reference Guide describes the central processing unit (CPU) and the assembly language instructions of the TMS320C28x fixed-point digital signal processors (DSPs). It also describes emulation features available on these DSPs.

# Tools Guides—

- SPRU513 TMS320C28x Assembly Language Tools v5.0.0 User's Guide describes the assembly language tools (assembler and other tools used to develop assembly language code), assembler directives, macros, common object file format, and symbolic debugging directives for the TMS320C28x device.
- SPRU514 TMS320C28x Optimizing C/C++ Compiler v5.0.0 User's Guide describes the TMS320C28x<sup>™</sup> C/C++ compiler. This compiler accepts ANSI standard C/C++ source code and produces TMS320 DSP assembly language source code for the TMS320C28x device.
- SPRU608 TMS320C28x Instruction Set Simulator Technical Overview describes the simulator, available within the Code Composer Studio for TMS320C2000 IDE, that simulates the instruction set of the C28x<sup>™</sup> core.
- SPRS797 TMS320F28055, TMS320F28054, TMS320F28053, TMS320F28052, TMS320F28051, TMS320F28050 Piccolo Microcontrollers Data Manual contains the pinout, signal descriptions, as well as electrical and timing specifications for the F2805x device.
- SPRZ362— TMS320F28055, TMS320F28054, TMS320F28053, TMS320F28052, TMS320F28051, TMS320F28050 Piccolo MCU Silicon Errata describes known advisories on silicon and provides workarounds.

TMS320C28x, C28x, TMS320x28x, 28x, 27x, C2xLP, Piccolo, TMS470, 240x are trademarks of Texas Instruments. Code Composer Studio is a trademark of TI . XDS is a trademark of XDS. All other trademarks are the property of their respective owners.



# System Control and Interrupts

This chapter describes the proper sequence to configure the wait states and operating mode of flash and one-time programmable (OTP) memories. It also includes information on flash and OTP power modes and how to improve flash performance by enabling the flash pipeline mode.

This chapter also describes how various system controls and interrupts work. It includes information on:

- Flash and one-time programmable (OTP) memories.
- Dual code security module (DCSM), which is a security feature incorporated in TMS320x28x<sup>™</sup> devices.
- Clocking mechanisms including the oscillator, PLL, XCLKOUT, watchdog module, and the low-power modes. In addition, the 32-bit CPU-Timers are also described.
- GPIO multiplexing (MUX) registers used to select the operation of shared pins on the device.
- Accessingo the peripheral frames to write to and read from various peripheral registers on the device.
- Interrupt sources, both external and the peripheral interrupt expansion (PIE) block that multiplexes numerous interrupt sources into a smaller set of interrupt inputs.

#### Topic

Page

| 1.1 | Flash and OTP Memory 33                  |  |
|-----|------------------------------------------|--|
| 1.2 | Clocking                                 |  |
| 1.3 | General-Purpose Input/Output (GPIO)      |  |
| 1.4 | Peripheral Frames 115                    |  |
| 1.5 | Peripheral Interrupt Expansion (PIE) 125 |  |
| 1.6 | VREG/BOR/POR                             |  |
| 1.7 | Dual Code Security Module (DCSM) 151     |  |
| 1.8 | DCSM Registers 165                       |  |
|     |                                          |  |



# 1.1 Flash and OTP Memory

This section describes how to configure flash and one-time programmable (OTP) memory.

# 1.1.1 Flash Memory

The on-chip flash is uniformly mapped in both program and data memory space. This flash memory is always enabled and features:

# Multiple sectors

The minimum amount of flash memory that can be erased is a sector. Having multiple sectors provides the option of leaving some sectors programmed and only erasing specific sectors.

#### • Code security

The flash is protected by the Dual Code Security Module (DCSM). By programming a password into the flash, the user can prevent access to the flash by unauthorized persons. See Section 1.7 for information in using the Dual Code Security Module.

#### Low power modes

To save power when the flash is not in use, two levels of low power modes are available. See Section 1.7 for more information on the available flash power modes.

# Configurable wait states

Configurable wait states can be adjusted based on CPU frequency to give the best performance for a given execution speed.

#### Enhanced performance

A flash pipeline mode is provided to improve performance of linear code execution.

# 1.1.2 OTP Memory

The 1K x 16 block of one-time programmable (OTP) memory is uniformly mapped in both program and data memory space. The OTP should be strictly reserved for data programmed from TI or security related content. This block, unlike flash, can be programmed only one time and cannot be erased.

# 1.1.3 Flash and OTP Power Modes

The following operating states apply to the flash and OTP memory:

# • Reset or Sleep State

This is the state after a device reset. In this state, the bank and pump are in a sleep state (lowest power). When the flash is in the sleep state, a CPU data read or opcode fetch to the flash or OTP memory map area will automatically initiate a change in power modes to the standby state and then to the active state. During this transition time to the active state, the CPU will automatically be stalled. Once the transition to the active state is completed, the CPU access will complete as normal.

# • Standby State

In this state, the bank and pump are in standby power mode state. This state uses more power then the sleep state, but takes a shorter time to transition to the active or read state. When the flash is in the standby state, a CPU data read or opcode fetch to the flash or OTP memory map area will automatically initiate a change in power modes to the active state. During this transition time to the active state, the CPU will automatically be stalled. Once the flash/OTP has reached the active state, the CPU access will complete as normal.

# • Active or Read State

In this state, the bank and pump are in active power mode state (highest power). The CPU read or fetch access wait states to the flash/OTP memory map area is controlled by the FBANKWAIT and FOTPWAIT registers. A prefetch mechanism called flash pipeline can also be enabled to improve fetch performance for linear code execution.

**NOTE:** During the boot process, the boot ROM performs a dummy read of the Dual Code Security Module (DCSM) password locations located in the OTP. This read is performed to unlock a new or erased device that has no password stored in it so that flash programming or loading of code into security-protected SARAM can be performed. On devices with a password stored, this read has no effect and the device remains locked (see the Section 1.7 for more information). One effect of this read is that the flash will transition from the sleep (reset) state to the active state.

The flash/OTP bank and pump are always in the same power mode. See Figure 1-1 for a graphic depiction of the available power states. You can change the current flash/OTP memory power state as follows:

# • To move to a lower power state

Change the PWR mode bits from a higher power mode to a lower power mode. This change instantaneously moves the flash/OTP bank to the lower power state. This register should be accessed only by code running outside the flash/OTP memory.

# • To move to a higher power state

To move from a lower power state to a higher power state, there are two options.

- 1. Change the FPWR register from a lower state to a higher state. This access brings the flash/OTP memory to the higher state.
- 2. Access the flash or OTP memory by a read access or program opcode fetch access. This access automatically brings the flash/OTP memory to the active state.

There is a delay when moving from a lower power state to a higher one. See Figure 1-1. This delay is required to allow the flash to stabilize at the higher power mode. If any access to the flash/OTP memory occurs during this delay the CPU automatically stalls until the delay is complete.





The duration of the delay is determined by the FSTDBYWAIT and FACTIVEWAIT registers. Moving from the sleep state to a standby state is delayed by a count determined by the FSTDBYWAIT register. Moving from the standby state to the active state is delayed by a count determined by the FACTIVEWAIT register. Moving from the sleep mode (lowest power) to the active mode (highest power) is delayed by FSTDBYWAIT + FACTIVEWAIT. These registers should be left in their default state.

# 1.1.3.1 Flash and OTP Performance

CPU read or data fetch operations to the flash/OTP can take one of the following forms:

- 32-bit instruction fetch
- 16-bit or 32-bit data space read
- 16-bit program space read

Once flash is in the active power state, then a read or fetch access to the bank memory map area can be classified as a flash access or an OTP access.

The main flash array is organized into rows and columns. The rows contain 2048 bits of information. Accesses to flash and OTP are one of three types:

#### 1. Flash Memory Random Access

The first access to a 2048 bit row is considered a random access.

#### 2. Flash Memory Paged Access

While the first access to a row is considered a random access, subsequent accesses within the same row are termed paged accesses.

The number of wait states for both a random and a paged access can be configured by programming the FBANKWAIT register. The number of wait states used by a random access is controlled by the RANDWAIT bits and the number of wait states used by a paged access is controlled by the PAGEWAIT bits. The FBANKWAIT register defaults to a worst-case wait state count and, thus, needs

#### Flash and OTP Memory

to be initialized for the appropriate number of wait states to improve performance based on the CPU clock rate and the access time of the flash. The flash supports 0-wait accesses when the PAGEWAIT bits are set to zero. This assumes that the CPU speed is low enough to accommodate the access time. To determine the random and paged access time requirements, refer to the data manual for your particular device.

## 3. OTP Access

Read or fetch accesses to the OTP are controlled by the OTPWAIT bits in the FOTPWAIT register. Accesses to the OTP take longer than the flash and there is no paged mode. To determine OTP access time requirements, see the data manual for your particular device.

Some other points to keep in mind when working with flash:

- CPU writes to the flash or OTP memory map area are ignored. They complete in a single cycle.
- When the Dual Code Security Module (DCSM) is secured, reads to the flash/OTP memory map area from outside the secure zone take the same number of cycles as a normal access. However, the read operation returns a zero.
- Reads of the password locations are hardwired for 16 wait-states. The PAGEWAIT and RANDOMWAIT bits have no effect on these locations. See Section 1.7 for more information.

#### 1.1.3.2 Flash Pipeline Mode

Flash memory is typically used to store application code. During code execution, instructions are fetched from sequential memory addresses, except when a discontinuity occurs. Usually the portion of the code that resides in sequential addresses makes up the majority of the application code and is referred to as linear code. To improve the performance of linear code execution, a flash pipeline mode has been implemented. The flash pipeline feature is disabled by default. Setting the ENPIPE bit in the FOPT register enables this mode. The flash pipeline mode is independent of the CPU pipeline.

An instruction fetch from the flash or OTP reads out 64 bits per access. The starting address of the access from flash is automatically aligned to a 64-bit boundary such that the instruction location is within the 64 bits to be fetched. With flash pipeline mode enabled (see Figure 1-2), the 64 bits read from the instruction fetch are stored in a 64-bit wide by 2-level deep instruction pre-fetch buffer. The contents of this pre-fetch buffer are then sent to the CPU for processing as required.

Up to two 32-bit instructions or up to four 16-bit instructions can reside within a single 64-bit access. The majority of these instructions is 16 bits, so for every 64-bit instruction fetch from the flash bank it is likely that there are up to four instructions in the pre-fetch buffer ready to process through the CPU. During the time it takes to process these instructions, the flash pipeline automatically initiates another access to the flash bank to pre-fetch the next 64 bits. In this manner, the flash pipeline mode works in the background to keep the instruction pre-fetch buffers as full as possible. Using this technique, the overall efficiency of sequential code execution from flash or OTP is improved significantly.







The flash pipeline pre-fetch is aborted only on a PC discontinuity caused by executing an instruction such as a branch, BANZ, call, or loop. When this occurs, the pre-fetch is aborted and the contents of the pre-fetch buffer are flushed. There are two possible scenarios when this occurs:

- 1. If the destination address is within the flash or OTP, the pre-fetch aborts and then resumes at the destination address.
- 2. If the destination address is outside of the flash and OTP, the pre-fetch is aborted and begins again only when a branch is made back into the flash or OTP. The flash pipeline pre-fetch mechanism only applies to instruction fetches from program space. Data reads from data memory and from program memory do not utilize the pre-fetch buffer capability and thus bypass the pre-fetch buffer. For example, instructions such as MAC, DMAC, and PREAD read a data value from program memory. When this read happens, the pre-fetch buffer is bypassed but the buffer is not flushed. If an instruction pre-fetch is already in progress when a data read operation is initiated, then the data read will be stalled until the pre-fetch completes.



# 1.1.3.3 Procedure to Change the Flash Configuration Registers

During flash configuration, no accesses to the flash or OTP can be in progress. This includes instructions still in the CPU pipeline, data reads, and instruction pre-fetch operations. To be sure that no access takes place during the configuration change, you should follow the procedure shown in Figure 1-3 for any code that modifies the FOPT, FPWR, FBANKWAIT, or FOTPWAIT registers.





# 1.1.4 Flash and OTP Registers

The flash and OTP memory can be configured by the registers shown in Table 1-1. The configuration registers are all EALLOW protected. The bit descriptions are in Figure 1-4 through Figure 1-10.

| Name (1) (2)               | Address | Size (x16) | Description                           | Bit Description |
|----------------------------|---------|------------|---------------------------------------|-----------------|
| FOPT                       | 0x0A80  | 1          | Flash Option Register                 | Figure 1-4      |
| Reserved                   | 0x0A81  | 1          | Reserved                              |                 |
| FPWR                       | 0x0A82  | 1          | Flash Power Modes Register            | Figure 1-5      |
| FSTATUS                    | 0x0A83  | 1          | Status Register                       | Figure 1-6      |
| FSTDBYWAIT <sup>(3)</sup>  | 0x0A84  | 1          | Flash Sleep To Standby Wait Register  | Figure 1-7      |
| FACTIVEWAIT <sup>(3)</sup> | 0x0A85  | 1          | Flash Standby To Active Wait Register | Figure 1-8      |
| FBANKWAIT                  | 0x0A86  | 1          | Flash Read Access Wait State Register | Figure 1-9      |
| FOTPWAIT                   | 0x0A87  | 1          | OTP Read Access Wait State Register   | Figure 1-10     |

| Table 1-1. I | Flash/OTP | Configuration | Registers |
|--------------|-----------|---------------|-----------|
|--------------|-----------|---------------|-----------|

<sup>(1)</sup> These registers are EALLOW protected. See Section 1.4.2 for information.

<sup>(2)</sup> These registers are protected by the Dual Code Security Module (DCSM). See Section 1.7 for more information.

<sup>(3)</sup> These registers should be left in their default state.

**NOTE:** The flash configuration registers should not be written to by code that is running from OTP or flash memory or while an access to flash or OTP may be in progress. All register accesses to the flash registers should be made from code executing outside of flash/OTP memory and an access should not be attempted until all activity on the flash/OTP has completed. No hardware is included to protect against this.

To summarize, you can read the flash registers from code executing in flash/OTP; however, do not write to the registers.

CPU write access to the flash configuration registers can be enabled only by executing the EALLOW instruction. Write access is disabled when the EDIS instruction is executed. This protects the registers from spurious accesses. Read access is always available. The registers can be accessed through the JTAG port without the need to execute EALLOW. See Section 1.4.2 for information on EALLOW protection. These registers support both 16-bit and 32-bit accesses.



#### Flash and OTP Memory

www.ti.com

Figure 1-4. Flash Options Register (FOPT)

| 15 1     | 0         |
|----------|-----------|
| Reserved | ENPIPE    |
| R-0      | <br>R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-2. Flash Options Register (FOPT) Field Descriptions

| Bit  | Field    | Value | Description <sup>(1)</sup> <sup>(2)</sup> <sup>(3)</sup>                                                                                                                                                                  |
|------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-1 | Reserved |       |                                                                                                                                                                                                                           |
| 0    | ENPIPE   |       | Enable Flash Pipeline Mode Bit. Flash pipeline mode is active when this bit is set. The pipeline mode improves performance of instruction fetches by pre-fetching instructions. See Section 1.1.3.2 for more information. |
|      |          |       | When pipeline mode is enabled, the flash wait states (paged and random) must be greater than zero.                                                                                                                        |
|      |          |       | On flash devices, ENPIPE affects fetches from flash and OTP.                                                                                                                                                              |
|      |          | 0     | Flash Pipeline mode is not active. (default)                                                                                                                                                                              |
|      |          | 1     | Flash Pipeline mode is active.                                                                                                                                                                                            |

(1) This register is EALLOW protected. See Section 1.4.2 for more information.

(2) This register is protected by the Dual Code Security Module (DCSM). See Section 1.7 for more information.

(3) When writing to this register, follow the procedure described in Section 1.1.3.3.

# Figure 1-5. Flash Power Register (FPWR)

| 15 2     | 1   | 0   |
|----------|-----|-----|
| Reserved | PV  | VR  |
| R-0      | R/V | N-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-3. Flash Power Register (FPWR) Field Descriptions

| Bit  | Field    | Value | Description <sup>(1)</sup> <sup>(2)</sup>                                                                                                                                                     |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-2 | Reserved |       |                                                                                                                                                                                               |
| 1-0  | PWR      |       | Flash Power Mode Bits. Writing to these bits changes the current power mode of the flash bank and pump. See section Section 1.1.3 for more information on changing the flash bank power mode. |
|      |          | 00    | Pump and bank sleep (lowest power)                                                                                                                                                            |
|      |          | 01    | Pump and bank standby                                                                                                                                                                         |
|      |          | 10    | Reserved (no effect)                                                                                                                                                                          |
|      |          | 11    | Pump and bank active (highest power)                                                                                                                                                          |

(1) This register is EALLOW protected. See Section 1.4.2 for more information.

(2) This register is protected by the Dual Code Security Module (DCSM). See Section 1.7 for more information.



Flash and OTP Memory

| Figure 1-6. Flash Status Register (FSTATUS) |          |          |             |            |    |         |
|---------------------------------------------|----------|----------|-------------|------------|----|---------|
| 15                                          |          |          |             |            | 9  | 8       |
|                                             |          | Reserved |             |            |    | 3VSTAT  |
|                                             |          | R-0      |             |            |    | R/W1C-0 |
| 7                                           |          | 4        | 3           | 2          | 1  | 0       |
|                                             | Reserved |          | ACTIVEWAITS | STDBYWAITS | P\ | WRS     |
|                                             | R-0      |          | R-0         | R-0        | F  | २-०     |

LEGEND: R/W = Read/Write; R = Read only; W1C = Write 1 to clear; -n = value after reset

| Table 1-4. Flas | sh Status Registe | r (FSTATUS) | Field Descriptions |
|-----------------|-------------------|-------------|--------------------|
|-----------------|-------------------|-------------|--------------------|

| Bit  | Field       | Value | Description <sup>(1) (2)</sup>                                                                                                                                                                                                     |  |
|------|-------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15-9 | Reserved    |       | Reserved                                                                                                                                                                                                                           |  |
| 8    | 3VSTAT      |       | Flash Voltage ( $V_{DD3VFL}$ ) Status Latch Bit. When set, this bit indicates that the 3VSTAT signal from the pump module went to a high level. This signal indicates that the flash 3.3-V supply went out of the allowable range. |  |
|      |             | 0     | Writes of 0 are ignored.                                                                                                                                                                                                           |  |
|      |             | 1     | When this bit reads 1, it indicates that the flash 3.3-V supply went out of the allowable range.                                                                                                                                   |  |
|      |             |       | Clear this bit by writing a 1.                                                                                                                                                                                                     |  |
| 7-4  | Reserved    |       | Reserved                                                                                                                                                                                                                           |  |
| 3    | ACTIVEWAITS |       | Bank and Pump Standby To Active Wait Counter Status Bit. This bit indicates whether the respective wait counter is timing out an access.                                                                                           |  |
|      |             | 0     | The counter is not counting.                                                                                                                                                                                                       |  |
|      |             | 1     | The counter is counting.                                                                                                                                                                                                           |  |
| 2    | STDBYWAITS  |       | Bank and Pump Sleep To Standby Wait Counter Status Bit. This bit indicates whether the respective wait counter is timing out an access.                                                                                            |  |
|      |             | 0     | The counter is not counting.                                                                                                                                                                                                       |  |
|      |             | 1     | The counter is counting.                                                                                                                                                                                                           |  |
| 1-0  | PWRS        |       | Power M odes Status Bits. These bits indicate which power mode the flash/OTP is currently in.                                                                                                                                      |  |
|      |             |       | The PWRS bits are set to the new power mode only after the appropriate timing delays have expired.                                                                                                                                 |  |
|      |             | 00    | Pump and bank in sleep mode (lowest power)                                                                                                                                                                                         |  |
|      |             | 01    | Pump and bank in standby mode                                                                                                                                                                                                      |  |
|      |             | 10    | Reserved                                                                                                                                                                                                                           |  |
|      |             | 11    | Pump and bank active and in read mode (highest power)                                                                                                                                                                              |  |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> This register is protected by the Dual Code Security Module (DCSM). See Section 1.7 for more information.

# Flash and OTP Memory

Figure 1-7. Flash Standby Wait Register (FSTDBYWAIT)

15 9 8 0 STDBYWAIT Reserved R/W-0x1FF R-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-5. Flash Standby Wait Register (FSTDBYWAIT) Field Descriptions

| Bit  | Field     | Value     | Description <sup>(1) (2)</sup>                     |
|------|-----------|-----------|----------------------------------------------------|
| 15-9 | Reserved  | 0         | Reserved                                           |
| 8-0  | STDBYWAIT |           | This register should be left in its default state. |
|      |           |           | Bank and Pump Sleep To Standby Wait Count.         |
|      |           | 111111111 | 511 SYSCLKOUT cycles (default)                     |

(1) This register is EALLOW protected. See Section 1.4.2 for more information.

(2) This register is protected by the Dual Code Security Module (DCSM). See Section 1.7 for more information.

# Figure 1-8. Flash Standby to Active Wait Counter Register (FACTIVEWAIT)

| 7        | 9 | 8 | 0          |
|----------|---|---|------------|
| Reserved |   |   | ACTIVEWAIT |
| R-0      |   |   | R/W-0x1FF  |
|          |   |   |            |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-6. Flash Standby to Active Wait Counter Register (FACTIVEWAIT) Field Descriptions

| Bits | Field      | Value     | Description <sup>(1) (2)</sup>                     |
|------|------------|-----------|----------------------------------------------------|
| 15-9 | Reserved   | 0         | Reserved                                           |
| 8-0  | ACTIVEWAIT |           | This register should be left in its default state. |
|      |            |           | Bank and Pump Standby To Active Wait Count:        |
|      |            | 111111111 | 511 SYSCLKOUT cycles (default)                     |

This register is EALLOW protected. See Section 1.4.2 for more information. (1)

(2) This register is protected by the Dual Code Security Module (DCSM). See Section 1.7 for more information. www.ti.com



Flash and OTP Memory

| Figure 1-9. Flash Wait-State Register (FBANKWAIT) |                 |                     |                |        |                |         |          |  |
|---------------------------------------------------|-----------------|---------------------|----------------|--------|----------------|---------|----------|--|
| 15                                                | 12              | 11                  | 8              | 7      | 4              | 3       | 0        |  |
| Reser                                             | rved            | PAGE                | VAIT           |        | Reserved RANDW |         | RANDWAIT |  |
| R-(                                               | 0               | R/W-(               | 0xF            | R-0 R/ |                | R/W-0xF |          |  |
|                                                   | Road/Write: R - | Read only: _n - val | up ofter recet |        |                |         |          |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-7. Flash Wait-State Register (FBANKWAIT) Field Descriptions

| Bits  | Field    | Value | Description <sup>(1)</sup> <sup>(2)</sup> <sup>(3)</sup>                                                                                                                                                                                                                     |
|-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Reserved |       | Reserved                                                                                                                                                                                                                                                                     |
| 11-8  | PAGEWAIT |       | Flash Paged Read Wait States. These register bits specify the number of wait states for a paged read operation in CPU clock cycles (015 SYSCLKOUT cycles) to the flash bank. See Section 1.1.3.1 for more information.                                                       |
|       |          |       | See the device-specific data manual for the minimum time required for a PAGED flash access.                                                                                                                                                                                  |
|       |          |       | You must set RANDWAIT to a value greater than or equal to the PAGEWAIT setting. No hardware is provided to detect a PAGEWAIT value that is greater then RANDWAIT.                                                                                                            |
|       |          | 0000  | Zero wait-state per paged flash access or one SYSCLKOUT cycle per access                                                                                                                                                                                                     |
|       |          | 0001  | One wait state per paged flash access or a total of two SYSCLKOUT cycles per access                                                                                                                                                                                          |
|       |          | 0010  | Two wait states per paged flash access or a total of three SYSCLKOUT cycles per access                                                                                                                                                                                       |
|       |          | 0011  | Three wait states per paged flash access or a total of four SYSCLKOUT cycles per access                                                                                                                                                                                      |
|       |          |       |                                                                                                                                                                                                                                                                              |
|       |          | 1111  | 15 wait states per paged flash access or a total of 16 SYSCLKOUT cycles per access. (default)                                                                                                                                                                                |
| 7-4   | Reserved |       | Reserved                                                                                                                                                                                                                                                                     |
| 3-0   | RANDWAIT |       | Flash Random Read Wait States. These register bits specify the number of wait states for a random read operation in CPU clock cycles (115 SYSCLKOUT cycles) to the flash bank. See Section 1.1.3.1 for more information.                                                     |
|       |          |       | See the device-specific data manual for the minimum time required for a RANDOM flash access.                                                                                                                                                                                 |
|       |          |       | RANDWAIT must be set greater than 0. That is, at least 1 random wait state must be used. In addition, you must set RANDWAIT to a value greater than or equal to the PAGEWAIT setting. The device will not detect and correct a PAGEWAIT value that is greater then RANDWAIT. |
|       |          | 0000  | Illegal value. RANDWAIT must be set greater then 0.                                                                                                                                                                                                                          |
|       |          | 0001  | One wait state per random flash access or a total of two SYSCLKOUT cycles per access.                                                                                                                                                                                        |
|       |          | 0010  | Two wait states per random flash access or a total of three SYSCLKOUT cycles per access.                                                                                                                                                                                     |
|       |          | 0011  | Three wait states per random flash access or a total of four SYSCLKOUT cycles per access.                                                                                                                                                                                    |
|       |          |       |                                                                                                                                                                                                                                                                              |
|       |          | 1111  | 15 wait states per random flash access or a total of 16 SYSCLKOUT cycles per access. (default)                                                                                                                                                                               |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> This register is protected by the Dual Code Security Module (DCSM). See Section 1.7 for more information.

<sup>(3)</sup> When writing to this register, follow the procedure described in Section 1.1.3.3.



#### Flash and OTP Memory

www.ti.com

Figure 1-10. OTP Wait-State Register (FOTPWAIT)

| 15 5     | 5 | 4        | 0 |
|----------|---|----------|---|
| Reserved |   | OTPWAIT  |   |
| R-0      |   | R/W-0x1F |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-8. OTP Wait-State Register (FOTPWAIT) Field Descriptions

| Bit(s) | Field    | Value | Description <sup>(1)</sup> <sup>(2)</sup> <sup>(3)</sup>                                                                                                                                                                                                   |
|--------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-5   | Reserved | 0     | Reserved                                                                                                                                                                                                                                                   |
| 4-0    | OTPWAIT  |       | OTP Read Wait States. These register bits specify the number of wait states for a read operation in CPU clock cycles (131 SYSCLKOUT cycles) to the OTP. See CPU Read Or Fetch Access From flash/OTP section for details. There is no PAGE mode in the OTP. |
|        |          |       | OTPWAIT must be set greater than 0. That is, a minimum of 1 wait state must be used. See the device-specific data manual for the minimum time required for an OTP access.                                                                                  |
|        |          | 00000 | Illegal value. OTPWAIT must be set to 1 or greater.                                                                                                                                                                                                        |
|        |          | 00001 | One wait state will be used each OTP access for a total of two SYSCLKOUT cycles per access.                                                                                                                                                                |
|        |          | 00010 | Two wait states will be used for each OTP access for a total of three SYSCLKOUT cycles per access.                                                                                                                                                         |
|        |          | 00011 | Three wait states will be used for each OTP access for a total of four SYSCLKOUT cycles per access.                                                                                                                                                        |
|        |          |       |                                                                                                                                                                                                                                                            |
|        |          | 11111 | 31 wait states will be used for an OTP access for a total of 32 SYSCLKOUT cycles per access.                                                                                                                                                               |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> This register is protected by the Dual Code Security Module (DCSM). See Section 1.7 for more information.

<sup>(3)</sup> When writing to this register, follow the procedure described in Section 1.1.3.3.



# 1.2 Clocking

This section describes the oscillator, PLL and clocking mechanisms, the watchdog function, and the low-power modes.

# 1.2.1 Clocking and System Control

Figure 1-11 shows the various clock and reset domains.



Figure 1-11. Clock and Reset Domains

The PLL, clocking, watchdog and low-power modes, are controlled by the registers listed in Table 1-9.

Texas STRUMENTS

www.ti.com

Clocking

| Name        | Address     | Size<br>(x16) | Description                                    |
|-------------|-------------|---------------|------------------------------------------------|
| XCLK        | 0x0000-7010 | 1             | XCLKOUT/XCLKIN Control                         |
| PLLSTS      | 0x0000-7011 | 1             | PLL Status Register                            |
| CLKCTL      | 0x0000-7012 | 1             | Clock Control Register                         |
| PLLLOCKPRD  | 0x0000-7013 | 1             | PLL Lock Period Register                       |
| INTOSC1TRIM | 0x0000-7014 | 1             | Internal Oscillator 1 Trim Register            |
| INTOSC2TRIM | 0x0000-7016 | 1             | Internal Oscillator 2 Trim Register            |
| LOSPCP      | 0x0000-701B | 1             | Low-Speed Peripheral Clock Pre-Scaler Register |
| PCLKCR0     | 0x0000-701C | 1             | Peripheral Clock Control Register 0            |
| PCLKCR1     | 0x0000-701D | 1             | Peripheral Clock Control Register 1            |
| LPMCR0      | 0x0000-701E | 1             | Low Power Mode Control Register 0              |
| PCLKCR3     | 0x0000-7020 | 1             | Peripheral Clock Control Register 3            |
| PLLCR       | 0x0000-7021 | 1             | PLL Control Register                           |
| SCSR        | 0x0000-7022 | 1             | System Control & Status Register               |
| WDCNTR      | 0x0000-7023 | 1             | Watchdog Counter Register                      |
| PCLKCR4     | 0x0000-7024 | 1             | Peripheral Clock Control Register 4            |
| WDKEY       | 0x0000-7025 | 1             | Watchdog Reset Key Register                    |
| WDCR        | 0x0000-7029 | 1             | Watchdog Control Register                      |
| BORCFG      | 0x000985    | 1             | BOR Configuration Register                     |

# 1.2.1.1 Enabling/Disabling Clocks to the Peripheral Modules

The PCLKCR0/1/3 registers enable/disable clocks to the various peripheral modules. There is a 2-SYSCLKOUT cycle delay from when a write to the PCLKCR0/1/3 registers occurs to when the action is valid. This delay must be taken into account before attempting to access the peripheral configuration registers. Due to the peripheral-GPIO multiplexing at the pin level, all peripherals cannot be used at the same time. While it is possible to turn on the clocks to all the peripherals at the same time, such a configuration may not be useful. If this is done, the current drawn will be more than required. To avoid this, only enable the clocks required by the application.

| 15       | 14         | 13        | 12        | 11        | 10        | 9        | 8         |
|----------|------------|-----------|-----------|-----------|-----------|----------|-----------|
| Reserved | ECANAENCLK | Rese      | erved     | SCIBENCLK | SCIAENCLK | Reserved | SPIAENCLK |
| R-0      | R/W-0      | R         | -0        | R/W-0     | R/W-0     | R-0      | R/W-0     |
| 7        | 6          | 5         | 4         | 3         | 2         | 1        | 0         |
| Reserved |            | SCICENCLK | I2CAENCLK | ADCENCLK  | TBCLKSYNC | Res      | served    |
| R-0      |            | R/W-0     | R/W-0     | R/W-0     | R/W-0     | F        | २-०       |
|          |            |           |           |           |           |          |           |

# Figure 1-12. Peripheral Clock Control 0 Register (PCLKCR0)

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bit   | Field      | Value | Description                                                |
|-------|------------|-------|------------------------------------------------------------|
| 15    | Reserved   |       | Reserved                                                   |
| 14    | ECANAENCLK |       | ECAN-A clock enable                                        |
|       |            | 0     | The eCAN-A module is not clocked. (default) <sup>(1)</sup> |
|       |            | 1     | The eCAN-A module is clocked (SYSCLKOUT/2).                |
| 13-12 | Reserved   |       | Reserved                                                   |

(1) If a peripheral block is not used, the clock to that peripheral can be turned off to minimize power consumption.

# Table 1-10. Peripheral Clock Control 0 Register (PCLKCR0) Field Descriptions (continued)

| Bit | Field     | Value | Description                                                                                                                                                                                                                                                                   |
|-----|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11  | SCIBENCLK |       | SCI-B clock enable                                                                                                                                                                                                                                                            |
|     |           | 0     | The SCI-B module is not clocked. (default) <sup>(1)</sup>                                                                                                                                                                                                                     |
|     |           | 1     | The SCI-B module is clocked by the low-speed clock (LSPCLK).                                                                                                                                                                                                                  |
| 10  | SCIAENCLK |       | SCI-A clock enable                                                                                                                                                                                                                                                            |
|     |           | 0     | The SCI-A module is not clocked. (default) <sup>(1)</sup>                                                                                                                                                                                                                     |
|     |           | 1     | The SCI-A module is clocked by the low-speed clock (LSPCLK).                                                                                                                                                                                                                  |
| 9   | Reserved  |       | Reserved                                                                                                                                                                                                                                                                      |
| 8   | SPIAENCLK |       | SPI-A clock enable                                                                                                                                                                                                                                                            |
|     |           | 0     | The SPI-A module is not clocked. (default) <sup>(2)</sup>                                                                                                                                                                                                                     |
|     |           | 1     | The SPI-A module is clocked by the low-speed clock (LSPCLK).                                                                                                                                                                                                                  |
| 7-6 | Reserved  |       | Reserved                                                                                                                                                                                                                                                                      |
| 5   | SCICENCLK |       | SCI-C clock enable                                                                                                                                                                                                                                                            |
|     |           | 0     | The SCI-C module is not clocked. (default) <sup>(1)</sup>                                                                                                                                                                                                                     |
|     |           | 1     | The SCI-C module is clocked by the low-speed clock (LSPCLK).                                                                                                                                                                                                                  |
| 4   | I2CAENCLK |       | I <sup>2</sup> C clock enable                                                                                                                                                                                                                                                 |
|     |           | 0     | The I <sup>2</sup> C module is not clocked. (default) <sup>(1)</sup>                                                                                                                                                                                                          |
|     |           | 1     | The I <sup>2</sup> C module is clocked.                                                                                                                                                                                                                                       |
| 3   | ADCENCLK  |       | ADC clock enable                                                                                                                                                                                                                                                              |
|     |           | 0     | The ADC is not clocked. (default) <sup>(3)</sup>                                                                                                                                                                                                                              |
|     |           | 1     | The ADC module is clocked                                                                                                                                                                                                                                                     |
| 2   | TBCLKSYNC |       | ePWM Module Time Base Clock (TBCLK) Sync: Allows the user to globally synchronize all enabled ePWM modules to the time base clock (TBCLK):                                                                                                                                    |
|     |           | 0     | The TBCLK (Time Base Clock) within each enabled ePWM module is stopped. (default). If, however, the ePWM clock enable bit is set in the PCLKCR1 register, then the ePWM module will still be clocked by SYSCLKOUT even if TBCLKSYNC is 0.                                     |
|     |           | 1     | All enabled ePWM module clocks are started with the first rising edge of TBCLK aligned. For perfectly synchronized TBCLKs, the prescaler bits in the TBCTL register of each ePWM module must be set identically. The proper procedure for enabling ePWM clocks is as follows: |
|     |           |       | Enable ePWM module clocks in the PCLKCR1 register.                                                                                                                                                                                                                            |
|     |           |       | • Set TBCLKSYNC to 0.                                                                                                                                                                                                                                                         |
|     |           |       | Configure prescaler values and ePWM modes.                                                                                                                                                                                                                                    |
|     |           |       | Set TBCLKSYNC to 1.                                                                                                                                                                                                                                                           |
| 1-0 | Reserved  |       | Reserved                                                                                                                                                                                                                                                                      |

<sup>(2)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(3)</sup> If a peripheral block is not used, the clock to that peripheral can be turned off to minimize power consumption.



| ocking                                                     |            |            |            |            |                   |            | www.ti.con |  |
|------------------------------------------------------------|------------|------------|------------|------------|-------------------|------------|------------|--|
| Figure 1-13. Peripheral Clock Control 1 Register (PCLKCR1) |            |            |            |            |                   |            |            |  |
| 15                                                         | 14         | 13         |            |            |                   | 9          | 8          |  |
| Reserved                                                   | EQEP1ENCLK |            |            | Reserved   |                   |            | ECAP1ENCLK |  |
| R-0                                                        | R/W-0      |            |            | R-0        |                   |            | R/W-0      |  |
| 7                                                          |            | 5          | 4          | 3          | 2                 | 1          | 0          |  |
| Reserved                                                   | EPWM7ENCLK | EPWM6ENCLK | EPWM5ENCLK | EPWM4ENCLK | <b>EPWM3ENCLK</b> | EPWM2ENCLK | EPWM1ENCLK |  |
|                                                            | R-0        |            | R/W-0      | R/W-0      | R/W-0             | R/W-0      | R/W-0      |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-11. Peripheral Clock Control 1 Register (PCLKCR1) Field Descriptions

| Bits | Field      | Value | Description <sup>(1)</sup>                                   |
|------|------------|-------|--------------------------------------------------------------|
| 15   | Reserved   |       | Reserved                                                     |
| 14   | EQEP1ENCLK |       | eQEP1 clock enable                                           |
|      |            | 0     | The eQEP1 module is not clocked. (default) <sup>(2)</sup>    |
|      |            | 1     | The eQEP1 module is clocked by the system clock (SYSCLKOUT). |
| 13-9 | Reserved   |       | Reserved                                                     |
| 8    | ECAP1ENCLK |       | eCAP1 clock enable                                           |
|      |            | 0     | The eCAP1 module is not clocked. (default) <sup>(2)</sup>    |
|      |            | 1     | The eCAP1 module is clocked by the system clock (SYSCLKOUT). |
| 7    | Reserved   |       | Reserved                                                     |
| 6    | EPWM7ENCLK |       | ePWM7 clock enable. (3)                                      |
|      |            | 0     | The ePWM7 module is not clocked. (default) <sup>(2)</sup>    |
|      |            | 1     | The ePWM7 module is clocked by the system clock (SYSCLKOUT). |
| 5    | EPWM6ENCLK |       | ePWM6 clock enable. (3)                                      |
|      |            | 0     | The ePWM6 module is not clocked. (default) (2)               |
|      |            | 1     | The ePWM6 module is clocked by the system clock (SYSCLKOUT). |
| 4    | EPWM5ENCLK |       | ePWM5 clock enable <sup>(3)</sup>                            |
|      |            | 0     | The ePWM5 module is not clocked. (default) <sup>(2)</sup>    |
|      |            | 1     | The ePWM5 module is clocked by the system clock (SYSCLKOUT). |
| 3    | EPWM4ENCLK |       | ePWM4 clock enable. (3)                                      |
|      |            | 0     | The ePWM4 module is not clocked. (default) <sup>(2)</sup>    |
|      |            | 1     | The ePWM4 module is clocked by the system clock (SYSCLKOUT). |
| 2    | EPWM3ENCLK |       | ePWM3 clock enable. (3)                                      |
|      |            | 0     | The ePWM3 module is not clocked. (default) <sup>(2)</sup>    |
|      |            | 1     | The ePWM3 module is clocked by the system clock (SYSCLKOUT). |
| 1    | EPWM2ENCLK |       | ePWM2 clock enable. (3)                                      |
|      |            | 0     | The ePWM2 module is not clocked. (default) <sup>(2)</sup>    |
|      |            | 1     | The ePWM2 module is clocked by the system clock (SYSCLKOUT). |
| 0    | EPWM1ENCLK |       | ePWM1 clock enable. (3)                                      |
|      |            | 0     | The ePWM1 module is not clocked. (default) <sup>(2)</sup>    |
|      |            | 1     | The ePWM1 module is clocked by the system clock (SYSCLKOUT). |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> If a peripheral block is not used, the clock to that peripheral can be turned off to minimize power consumption.

<sup>(3)</sup> To start the ePWM Time-base clock (TBCLK) within the ePWM modules, the TBCLKSYNC bit in PCLKCR0 must also be set.



Clocking

| Figure 1-14. Peripheral Clock Control 3 Register (PCLKCR3) |           |    |          |     |                |                |                |  |  |
|------------------------------------------------------------|-----------|----|----------|-----|----------------|----------------|----------------|--|--|
| 15                                                         | 14        | 13 |          | 11  | 10             | 9              | 8              |  |  |
| Reserved                                                   | CLA1ENCLK |    | Reserved |     | CPUTIMER2ENCLK | CPUTIMER1ENCLK | CPUTIMER0ENCLK |  |  |
| R-0                                                        | R/W-0     |    | R-0      |     | R/W-1          | R/W-1          | R/W-1          |  |  |
| 7                                                          |           |    |          |     |                |                | 0              |  |  |
|                                                            |           |    | Reser    | ved |                |                |                |  |  |
|                                                            |           |    | -        |     |                |                |                |  |  |

R-0

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 1-12. Peripheral Clock Control 3 Register (PCLKCR3) Field Descriptions

| Bit   | Field          | Value | Description                     |
|-------|----------------|-------|---------------------------------|
| 15    | Reserved       |       | Reserved                        |
| 14    | CLA1ENCLK      |       | CLA module clock enable         |
|       |                | 0     | CLA is not clocked              |
|       |                | 1     | CLA is clocked                  |
| 13-11 | Reserved       |       | Reserved                        |
| 10    | CPUTIMER2ENCLK |       | CPU Timer 2 Clock Enable        |
|       |                | 0     | The CPU Timer 2 is not clocked. |
|       |                | 1     | The CPU Timer 2 is clocked.     |
| 9     | CPUTIMER1ENCLK |       | CPU Timer 1 Clock Enable        |
|       |                | 0     | The CPU Timer 1 is not clocked. |
|       |                | 1     | The CPU Timer 1 is clocked.     |
| 8     | CPUTIMER0ENCLK |       | CPU Timer 0 Clock Enable        |
|       |                | 0     | The CPU Timer 0 is not clocked. |
|       |                | 1     | The CPU Timer 0 is clocked.     |
| 7:0   | Reserved       |       | Reserved                        |



Clocking

# Figure 1-15. Peripheral Clock Control 4 Register (PCLKCR4)

| 15       |               |   |          |    |              |              | 8            |
|----------|---------------|---|----------|----|--------------|--------------|--------------|
|          |               |   | Reserve  | ed |              |              |              |
| R-0      |               |   |          |    |              |              |              |
| 7        | 6             | 5 |          | 3  | 2            | 1            | 0            |
| Reserved | CTRIPPFCENCLK |   | Reserved |    | CTRIPB1ENCLK | CTRIPA3ENCLK | CTRIPA1ENCLK |
|          |               |   | R-0      |    |              |              |              |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-13. Peripheral Clock Control 4 Register (PCLKCR4) Field Descriptions

| Bit  | Field         | Value | Description                                                  |
|------|---------------|-------|--------------------------------------------------------------|
| 15-7 | Reserved      |       | Reserved                                                     |
| 6    | CTRIPPFCENCLK |       | Digital filter and comparator trip clock enable for CTRIPPFC |
|      |               | 0     | ComparatorTripPFC not clocked                                |
|      |               | 1     | ComparatorTripPFC clocked                                    |
| 5-3  | Reserved      |       | Reserved                                                     |
| 2    | CTRIPB1ENCLK  |       | Digital filter and comparator trip clock enable for CTRIPB1  |
|      |               | 0     | ComparatorTripB1 Not clocked                                 |
|      |               | 1     | ComparatorTripB1 clocked                                     |
| 1    | CTRIPA3ENCLK  |       | Digital filter and comparator trip clock enable for CTRIPA3  |
|      |               | 0     | ComparatorTripA3 not clocked                                 |
|      |               | 1     | ComparatorTripA3 clocked                                     |
| 0    | CTRIPA1ENCLK  |       | Digital filter and comparator trip clock enable for CTRIPA1  |
|      |               | 0     | ComparatorTripA1 not clocked                                 |
|      |               | 1     | ComparatorTripA1 clocked                                     |

# 1.2.1.2 Configuring the Low-Speed Peripheral Clock Prescaler

The low-speed peripheral clock prescale (LOSPCP) registers are used to configure the low-speed peripheral clocks. See Figure 1-16 for the LOSPCP layout.

# Figure 1-16. Low-Speed Peripheral Clock Prescaler Register (LOSPCP)

| 15       | 3 | 2 | 0       |
|----------|---|---|---------|
| Reserved |   |   | LSPCLK  |
| R-0      |   |   | R/W-010 |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 1-14. Low-Speed Peripheral Clock Prescaler Register (LOSPCP) Field Descriptions

| Bits | Field    | Value | Description <sup>(1)</sup>                                                               |
|------|----------|-------|------------------------------------------------------------------------------------------|
| 15-3 | Reserved |       | Reserved                                                                                 |
| 2-0  | LSPCLK   |       | These bits configure the low-speed peripheral clock (LSPCLK) rate relative to SYSCLKOUT: |
|      |          |       | If LOSPCP <sup>(2)</sup> ≠ 0, then LSPCLK = SYSCLKOUT/(LOSPCP X 2)                       |
|      |          |       | If LOSPCP = 0, then LSPCLK = SYSCLKOUT                                                   |
|      |          | 000   | Low speed clock = SYSCLKOUT/1                                                            |
|      |          | 001   | Low speed clock= SYSCLKOUT/2                                                             |
|      |          | 010   | Low speed clock= SYSCLKOUT/4 (reset default)                                             |
|      |          | 011   | Low speed clock= SYSCLKOUT/6                                                             |
|      |          | 100   | Low speed clock= SYSCLKOUT/8                                                             |
|      |          | 101   | Low speed clock= SYSCLKOUT/10                                                            |
|      |          | 110   | Low speed clock= SYSCLKOUT/12                                                            |
|      |          | 111   | Low speed clock= SYSCLKOUT/14                                                            |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> LOSPCP in this equation denotes the value of bits 2:0 in the LOSPCP register.

# 1.2.2 OSC and PLL Block

The on-chip oscillator and phase-locked loop (PLL) block provide the clocking signals for the device, as well as control for low-power mode (LPM) entry or exit.

# 1.2.2.1 Input Clock Options

These devices have two internal oscillators (INTOSC1 and INTOSC2) that need no external components. They also have an on-chip, PLL-based clock module. Figure 1-17 shows the different options that are available to clock the device.Following are the input clock options available:

- INTOSC1 (Internal zero-pin Oscillator 1): This is the on-chip internal oscillator 1. This can provide the clock for the Watchdog block, core and CPU-Timer 2. This is the default clock source upon reset.
- **INTOSC2 (Internal zero-pin Oscillator 2):** This is the on-chip internal oscillator 2. This can provide the clock for the Watchdog block, core and CPU-Timer 2. Both INTOSC1 and INTOSC2 can be independently chosen for the Watchdog block, core and CPU-Timer 2.
- **Crystal/Resonator Operation:** The on-chip crystal oscillator enables the use of an external crystal/resonator attached to the device to provide the time base. The crystal/resonator is connected to the X1/X2 pins.
- External clock source operation: If the on-chip crystal oscillator is not used, this mode allows it to be bypassed. The device clock is generated from an external clock source input on the XCLKIN pin. Note that the XCLKIN is multiplexed with GPIO19 or GPIO38 pin. The XCLKIN input can be selected as GPIO19 or GPIO38 via the XCLKINSEL bit in XCLK register. The CLKCTL[XCLKINOFF] bit disables this clock input (forced low). If the clock source is not used or the respective pins are used as GPIOs, the user should disable at boot time.

Clocking

CLKCTL[WDCLKSRCSEL] Internal OSC1CLK 0 OSC 1 (A) INTOSC1TRIM Reg OSCCLKSRC1 (10 MHz) WDCLK CPU-watchdog (OSC1CLK on XRS reset) OSCE 1 CLKCTL[INTOSC10FF] 1 = Turn OSC Off CLKCTL[OSCCLKSRCSEL] CLKCTL[INTOSC1HALT] WAKEOSC 1 = Ignore HALT 0 Internal OSC2CLK INTOSC2TRIM Reg<sup>(A)</sup> OSC 2 OSCCLK PLL / (10 MHz) Missing-clock-detect circuit (OSC1CLK on XRS reset) OSCE CLKCTL[TMR2CLKPRESCALE] CLKCTL[TMR2CLKSRCSEL] 1 = Turn OSC Off 10 SYNC Edge Detect CLKCTL[INTOSC2OFF] Prescale 11 /1, /2, /4, /8, /16 01, 10, 11 01 CPUTMR2CLK 1 = Ignore HALT 1 00 CLKCTL[INTOSC2HALT] SYSCLKOUT OSCCLKSRC2 0 0 = GPIO38CLKCTL[OSCCLKSRC2SEL] XCLK[XCLKINSEL] 1 = GPIO19 CLKCTL[XCLKINOFF] 0 GPIO19 **XCLKIN** or GPIO38 (from XCLKIN external oscillator EXTCLK (Crystal) WAKEOSC XTAL OSC (Oscillators enabled when this signal is high) Х2 0 = OSC on (default on reset) CLKCTL[XTALOSCOFF] 1 = Turn OSC off

Figure 1-17. Clocking Options

A Register loaded from TI OTP-based calibration function.

B See the device-specific datasheet for details on missing clock detection.

# 1.2.2.1.1 Trimming INTOSCn

The nominal frequency of both INTOSC1 and INTOSC2 is 10 MHz. Two 16-bit registers are provided for trimming each oscillator at manufacturing time (called coarse trim) and also provide you with a way to trim the oscillator using software (called fine trim). Both registers are the same so only one is shown with "n" in place of the numbers 1 or 2.

# Figure 1-18. Internal Oscillator n Trim (INTOSCnTRIM) Register

| 15       | 14       | 9 | 8        | 7 |            | 0 |
|----------|----------|---|----------|---|------------|---|
| Reserved | FINETRIM |   | Reserved |   | COARSETRIM |   |
| R-0      | R/W-0    |   | R-0      |   | R/W-0      |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-15. Internal Oscillator n Trim (INTOSCnTRIM) Register Field Descriptions

| Field      | Value                            | Description <sup>(1)</sup>                                       |
|------------|----------------------------------|------------------------------------------------------------------|
| Reserved   |                                  | Any writes to these bit(s) must always have a value of 0.        |
| FINETRIM   |                                  | 6-bit Fine Trim Value: Signed magnitude value (- 31 to + 31)     |
| Reserved   |                                  | Any writes to these bit(s) must always have a value of 0.        |
| COARSETRIM |                                  | 8-bit Coarse Trim Value: Signed magnitude value (- 127 to + 127) |
|            | Reserved<br>FINETRIM<br>Reserved | Reserved<br>FINETRIM<br>Reserved                                 |

<sup>)</sup> The internal oscillators are software trimmed with parameters stored in OTP. During boot time, the boot-ROM copies this value to the above registers.

# 1.2.2.1.2 Device\_Cal

The Device\_cal() routine is programmed into TI reserved memory by the factory. The boot ROM automatically calls the Device\_cal() routine to calibrate the internal oscillators and ADC with device specific calibration data. During normal operation, this process occurs automatically and no action is required by the user.

If the boot ROM is bypassed by Code Composer Studio during the development process, then the calibration must be initialized by application. For working examples, see the system initialization in the C/C++ Header Files and Peripheral Examples.

**NOTE:** Failure to initialize these registers will cause the oscillators and ADC to function out of specification. The following three steps describe how to call the Device\_cal routine from an application.

Step 1: Create a pointer to the Device\_cal function as shown in Example 2-4. This #define is included in the Header Files and Peripheral Examples.

Step 2: Call the function pointed to by Device\_cal() as shown in Example 2-4. The ADC clocks must be enabled before making this call.

# Example 1-1. Calling the Device\_cal() function

```
//Device_cal is a pointer to a function
//that begins at the address shown
# define Device_cal (void(*)(void))0x3D7C80
... ...
EALLOW;
SysCtrlRegs.PCLKCR0.bit.ADCENCLK = 1;
(*Device_cal)();
SysCtrlRegs.PCLKCR0.bit.ADCENCLK = 0;
EDIS;
...
```

Clocking



# 1.2.2.2 Configuring Input Clock Source and XCLKOUT Options

The XCLK register is used to choose the GPIO pin for XCLKIN input and to configure the XCLKOUT pin frequency.

#### Figure 1-19. Clocking (XCLK) Register

| 15       |           |           |          |   |      | 8      |
|----------|-----------|-----------|----------|---|------|--------|
|          |           |           | Reserved |   |      |        |
|          |           |           | R-0      |   |      |        |
| 7        | 6         | 5         |          | 2 | 1    | 0      |
| Reserved | XCLKINSEL |           | Reserved |   | XCLK | OUTDIV |
| R-0      | R/W-1     | R-0 R/W-0 |          |   | W-0  |        |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-16. Clocking (XCLK) Field Descriptions

| Bit  | Field                     | Value | Description <sup>(1)</sup>                                                                                     |
|------|---------------------------|-------|----------------------------------------------------------------------------------------------------------------|
| 15-7 | Reserved                  |       | Reserved                                                                                                       |
| 6    | XCLKINSEL                 |       | XCLKIN Source Select Bit: This bit selects the source                                                          |
|      |                           | 0     | GPIO38 is XCLKIN input source (this is also the JTAG port TCK source)                                          |
|      |                           | 1     | GPIO19 is XCLKIN input source                                                                                  |
| 5-2  | Reserved                  |       | Reserved                                                                                                       |
| 1-0  | XCLKOUTDIV <sup>(2)</sup> |       | XCLKOUT Divide Ratio: These two bits select the XCLKOUT frequency ratio relative to SYSCLKOUT. The ratios are: |
|      |                           | 00    | XCLKOUT = SYSCLKOUT/4                                                                                          |
|      |                           | 01    | XCLKOUT = SYSCLKOUT/2                                                                                          |
|      |                           | 10    | XCLKOUT = SYSCLKOUT                                                                                            |
|      |                           | 11    | XCLKOUT = Off                                                                                                  |

<sup>(1)</sup> The XCLKINSEL bit in the XCLK register is reset by  $\overline{XRS}$  input signal.

<sup>(2)</sup> Refer to the device datasheet for the maximum permissible XCLKOUT frequency.

# 1.2.2.3 Configuring Device Clock Domains

The CLKCTL register is used to choose between the avaliable clock sources and also configure device behavior during clock failure.

| Figure 1-20. Clock Collifol (CLKCTL) Register |                 |           |         |              |             |               |              |
|-----------------------------------------------|-----------------|-----------|---------|--------------|-------------|---------------|--------------|
| 15                                            | 14              | 13        | 12      | 11           | 10          | 9             | 8            |
| NMIRESETSEL                                   | XTALOSCOFF      | XCLKINOFF | WDHALTI | INTOSC2HALTI | INTOSC20FF  | INTOSC1HALTI  | INTOSC10FF   |
| R/W-0                                         | R/W-0           | R/W-0     | R/W-0   | R/W-0        | R/W-0       | R/W-0         | R/W-0        |
| 7                                             |                 | 5         | 4       | 3            | 2           | 1             | 0            |
|                                               | TMR2CLKPRESCALE |           | TMR2CL  | KSRCSEL      | WDCLKSRCSEL | OSCCLKSRC2SEL | OSCCLKSRCSEL |
|                                               | R/W-0           |           | R/      | W-0          | R/W-0       | R/W-0         | R/W-0        |

# Figure 1-20. Clock Control (CLKCTL) Register

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-17. Clock Control (CLKCTL) Register Field Descriptions

| Bit | Field       | Value | Description                                                                                                                                                 |
|-----|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | NMIRESETSEL |       | NMI Reset Select Bit: This bit selects between generating the MCLKRS signal directly when a missing clock condition is detected or the NMIRS reset is used: |
|     |             | 0     | MCLKRS is driven without any delay (default on reset)                                                                                                       |
|     |             | 1     | NMI Watcdog Reset (NMIRS) initiates MCLKRS                                                                                                                  |
|     |             |       | Note: The CLOCKFAIL signal is generated regardless of this mode selection.                                                                                  |



| Table 1-17. Clock Control (C | CLKCTL) Register Field | <b>Descriptions (continued)</b> |
|------------------------------|------------------------|---------------------------------|
|------------------------------|------------------------|---------------------------------|

| Bit | Field           | Value | Description                                                                                                                                                                                                                                                                                                        |
|-----|-----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14  | XTALOSCOFF      |       | Crystal Oscillator Off Bit: This bit could be used to turn off the crystal oscillator if it is not used.                                                                                                                                                                                                           |
|     |                 | 0     | Crystal oscillator on (default on reset)                                                                                                                                                                                                                                                                           |
|     |                 | 1     | Crystal oscillator off                                                                                                                                                                                                                                                                                             |
| 13  | XCLKINOFF       |       | XCLKIN Off Bit: This bit turns external XCLKIN oscillator input off:                                                                                                                                                                                                                                               |
|     |                 | 0     | XCLKIN oscillator input on (default on reset)                                                                                                                                                                                                                                                                      |
|     |                 | 1     | XCLKIN oscillator input off                                                                                                                                                                                                                                                                                        |
|     |                 |       | <b>Note:</b> You need to select XCLKIN GPIO pin source via the XCLKINSEL bit in the XCLK register. See the XCLK register description for more details. XTALOSCOFF must be set to 1 if XCLKIN is used.                                                                                                              |
| 12  | WDHALTI         |       | Watchdog HALT Mode Ignore Bit: This bit selects if the watchdog is automatically turned on/off by the HALT mode or not. This feature can be used to allow the selected WDCLK source to continue clocking the watchdog when HALT mode is active. This would enable the watchdog to periodically wake up the device. |
|     |                 | 0     | Watchdog Automatically Turned On/Off By HALT (default on reset)                                                                                                                                                                                                                                                    |
|     |                 | 1     | Watchdog Ignores HALT Mode                                                                                                                                                                                                                                                                                         |
| 11  | INTOSC2HALTI    |       | Internal Oscillator 2 HALT Mode Ignore Bit: This bit selects if the internal oscillator 2 is automatically turned on/off by the HALT mode or not. This feature can be used to allow the internal oscillator to continue clocking when HALT mode is active. This would enable a quicker wake-up from HALT.          |
|     |                 | 0     | Internal Oscillator 2 Automatically Turned On/Off By HALT (default on reset)                                                                                                                                                                                                                                       |
|     |                 | 1     | Internal Oscillator 2 Ignores HALT Mode                                                                                                                                                                                                                                                                            |
| 10  | INTOSC20FF      |       | Internal Oscillator 2 Off Bit: This bit turns oscillator 2 off:                                                                                                                                                                                                                                                    |
|     |                 | 0     | Internal Oscillator 2 On (default on reset)                                                                                                                                                                                                                                                                        |
|     |                 | 1     | Internal Oscillator 2 Off. This bit could be used by the user to turn off the internal oscillator 2 if it is not used. This selection is not affected by the missing clock detect circuit.                                                                                                                         |
| 9   | INTOSC1HALTI    |       | Internal Oscillator 1 HALT Mode Ignore Bit: This bit selects if the internal oscillator 1 is automatically turned on/off by the HALT mode or not:                                                                                                                                                                  |
|     |                 | 0     | Internal Oscillator 1 Automatically Turned On/Off By HALT (default on reset)                                                                                                                                                                                                                                       |
|     |                 | 1     | Internal Oscillator 1 Ignores HALT Mode. This feature can be used to allow the internal oscillator to continue clocking when HALT mode is active. This would enable a quicker wake-up from HALT.                                                                                                                   |
| 8   | INTOSC10FF      |       | Internal Oscillator 1 Off Bit: This bit turns oscillator 1 off:                                                                                                                                                                                                                                                    |
|     |                 | 0     | Internal Oscillator 1 On (default on reset)                                                                                                                                                                                                                                                                        |
|     |                 | 1     | Internal Oscillator 1 Off. This bit could be used by the user to turn off the internal oscillator 1 if it is not used. This selection is not affected by the missing clock detect circuit.                                                                                                                         |
| 7-5 | TMR2CLKPRESCALE |       | CPU Timer 2 Clock Pre-Scale Value: These bits select the pre-scale value for the selected clock source for CPU Timer 2. This selection is not affected by the missing clock detect circuit.                                                                                                                        |
|     |                 | 000   | /1 (default on reset)                                                                                                                                                                                                                                                                                              |
|     |                 | 001   | /2                                                                                                                                                                                                                                                                                                                 |
|     |                 | 010   | /4                                                                                                                                                                                                                                                                                                                 |
|     |                 | 011   | /8                                                                                                                                                                                                                                                                                                                 |
|     |                 | 100   | /16                                                                                                                                                                                                                                                                                                                |
|     |                 | 101   | Reserved                                                                                                                                                                                                                                                                                                           |
|     |                 | 110   | Reserved                                                                                                                                                                                                                                                                                                           |
|     |                 | 111   | Reserved                                                                                                                                                                                                                                                                                                           |
| 4-3 | TMR2CLKSRCSEL   |       | CPU Timer 2 Clock Source Select Bit: This bit selects the source for CPU Timer 2:                                                                                                                                                                                                                                  |
|     |                 | 00    | SYSCLKOUT Selected (default on reset, pre-scaler is bypassed)                                                                                                                                                                                                                                                      |
|     |                 | 01    | External Oscillator Selected (at XOR output)                                                                                                                                                                                                                                                                       |
|     |                 | 10    | Internal Oscillator 1 Selected                                                                                                                                                                                                                                                                                     |
|     |                 | 11    | Internal Oscillator 2 Selected. This selection is not affected by the missing clock detect circuit.                                                                                                                                                                                                                |

TEXAS INSTRUMENTS

Clocking

www.ti.com

| Table 1-17. Clock Control (CLKCTL) Register | Field Descriptions (continued) |
|---------------------------------------------|--------------------------------|
|---------------------------------------------|--------------------------------|

| Bit | Field         | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | WDCLKSRCSEL   |       | Watchdog Clock Source Select Bit: This bit selects the source for WDCLK. On XRS low and after XRS goes high, internal oscillator 1 is selected by default. User would need to select external oscillator or Internal Oscillator 2 during their initialization process. If missing clock detect circuit detects a missing clock, then this bit is forced to 0 and internal oscillator 1 is selected. The user changing this bit does not affect the PLLCR value.                                                                                                                                                                                                                                                                                                                                                                   |
|     |               | 0     | Internal Oscillator 1 Selected (default on reset)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |               | 1     | External Oscillator or Internal Oscillator 2 Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1   | OSCCLKSRC2SEL |       | Oscillator 2 Clock Source Select Bit: This bit selects between internal oscillator 2 or external oscillator. This selection is not affected by the missing clock detect circuit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |               | 0     | External Oscillator Selected (default on reset)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |               | 1     | Internal Oscillator 2 Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0   | OSCCLKSRCSEL  |       | Oscillator Clock Source Select Bit. This bit selects the source for OSCCLK. On XRS low<br>and after XRS goes high, internal oscillator 1 is selected by default. User would need to<br>select external oscillator or Internal Oscillator 2 during their initialization process. Whenever<br>the user changes the clock source, using these bits, the PLLCR register will be<br>automatically forced to zero. This prevents potential PLL overshoot. The user will then have<br>to write to the PLLCR register to configure the appropriate divisor ratio. The user can also<br>configure the PLL lock period using the PLLLOCKPRD register to reduce the lock time if<br>necessary. If missing clock detect circuit detects a missing clock, then this bit is<br>automatically forced to zero to prevent any potential overshoot. |
|     |               | 0     | Internal Oscillator 1 Selected (default on reset)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |               | 1     | External Oscillator or Internal Oscillator 2 Selected Note: If users wish to use Oscillator 2 or External Oscillator to clock the CPU, they should configure the OSCCLKSRC2SEL bit first, and then write to the OSCCLKSRCSEL bit next.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

# 1.2.2.3.1 Switching the Input Clock Source

The following procedure may be used to switch clock sources:

- 1. Use CPU Timer 2 to detect if clock sources are functional.
- 2. If any of the clock sources is not functional, turn off the respective clock source (using the respective CLKCTL bit).
- 3. Switch over to a new clock source.
- 4. If clock source switching occurred while in Limp Mode, then an MCLKCLR will be issued to exit Limp Mode.

If External Oscillator or XCLKIN or Internal Oscillator 2 (OSCCLKSRC2) is selected and a missing clock is detected, the missing clock detect circuit will automatically switch to Internal Oscillator 1 (OSCCLKSRC1) and generate a CLOCKFAIL signal. In addition, the PLLCR register is forced to zero (PLL is bypassed) to prevent any potential overshoot. The user can then write to the PLLCR register to re-lock the PLL. Under this situation, the missing clock detect circuit will be automatically re-enabled (PLLSTS[MCLKSTS] bit will be automatically cleared). If Internal Oscillator 1 (OSCCLKSRC1) should also fail, then under this situation, the missing clock detect circuit will remain in limp mode. The user will have to re-enable the logic via the PLLSTS[MCLKCLR] bit.

# 1.2.2.3.2 Switching to INTOSC2 in the Absence of External Clocks

For the device to work properly upon a switch from INTOSC1 to INTOSC2 in the absence of any external clock, the application code needs to write a 1 to the CLKCTL.XTALOSCOFF and CLKCTL.XCLKINOFF bits first. This is to indicate to the clock switching circuitry that external clocks are not present. Only after this should the OSCCLKSRCSEL and OSCCLKSRC2SEL bits be written to. Note that this sequence should be separated into two writes as follows:

First write  $\rightarrow$  CLKCTL.XTALOSCOFF=1 and CLKCTL.XCLKINOFF=1

Second write  $\rightarrow$  CLKCTL.OSCCLKLSRCSEL=1 and CLKCTL.OSCCLKSRC2SEL=1

The second write should not alter the values of XTALOSCOFF and XCLKINOFF bits. If the header files supplied by Texas Instruments are used, clock switching can be achieved with the following code snip:



```
SysCtrlRegs.CLKCTL.all = 0x6000; // Set XTALOSCOFF=1 & XCLKINOFF=1
SysCtrlRegs.CLKCTL.all = 0x6003; // Set OSCCLKLSRCSEL=1 & OSCCLKSRC2SEL=1
```

The system initialization file (F2805x\_SysCtrl.c) provided as part of the header files also contain functions to switch to different clock sources. If an attempt is made to switch from INTOSC1 to INTOSC2 without the write to the XTALOSCOFF and XCLKINOFF bits, a missing clock will be detected due to the absence of external clock source (even after the proper source selection). The PLLCR will be zeroed out and the device will automatically clear the MCLKSTS bit and switch back INTOSC1.

# 1.2.2.4 PLL-based Clock Module

Figure 1-21 shows the OSC and PLL block diagram.



The following is applicable for devices that have X1 and X2 pins:

When using XCLKIN as the external clock source, you must tie X1 low and leave X2 disconnected.

| Table 1-18 | . Possible PL | L Configuration | Modes |
|------------|---------------|-----------------|-------|
|------------|---------------|-----------------|-------|

| PLL Mode    | Remarks                                                                                                                                                                                                                                                                                                                                                                               | PLLSTS[DIVSEL] (1) | CLKIN and<br>SYSCLKOUT <sup>(2)</sup> |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|---------------------------------------|
| PLL Off     | Invoked by the user setting the PLLOFF bit in the PLLSTS register. The                                                                                                                                                                                                                                                                                                                | 0, 1               | OSCCLK/4                              |
|             | PLL block is disabled in this mode. The CPU clock (CLKIN) can then be                                                                                                                                                                                                                                                                                                                 | 2                  | OSCCLK/2                              |
|             | derived directly from any one of the following sources: INTOSC1,<br>INTOSC2, XCLKIN pin, X1 pin or X1/X2 pins.This can be useful to<br>reduce system noise and for low power operation. The PLLCR register<br>must first be set to 0x0000 (PLL Bypass) before entering this mode. The<br>CPU clock (CLKIN) is derived directly from the input clock on either<br>X1/X2, X1 or XCLKIN. | 3                  | OSCCLK/1                              |
| PLL Bypass  | PLL Bypass is the default PLL configuration upon power-up or after an                                                                                                                                                                                                                                                                                                                 | 0, 1               | OSCCLK/4                              |
|             | external reset (XRS). This mode is selected when the PLLCR register is                                                                                                                                                                                                                                                                                                                | 2                  | OSCCLK/2                              |
|             | set to 0x0000 or while the PLL locks to a new frequency after the PLLCR register has been modified. In this mode, the PLL itself is bypassed but the PLL is not turned off.                                                                                                                                                                                                           | 3                  | OSCCLK/1                              |
| PLL Enabled | Achieved by writing a non-zero value n into the PLLCR register. Upon                                                                                                                                                                                                                                                                                                                  | 0, 1               | OSCCLK*n/4                            |
|             | writing to the PLLCR, the device will switch to PLL Bypass mode until                                                                                                                                                                                                                                                                                                                 | 2                  | OSCCLK*n/2                            |
|             | the PLL locks.                                                                                                                                                                                                                                                                                                                                                                        | 3                  | OSCCLK*n/1                            |

<sup>(1)</sup> PLLSTS[DIVSEL] must be 0 before writing to the PLLCR and should be changed only after PLLSTS[PLLLOCKS] = 1. See Figure 1-25.

<sup>(2)</sup> The input clock and PLLCR[DIV] bits should be chosen in such a way that the output frequency of the PLL (VCOCLK) is a minimum of 50 MHz.

# 1.2.2.5 Input Clock Fail Detection

It is possible for the clock source (internal or external) of the DSP to fail. When the PLL is not disabled, the main oscillator fail logic allows the device to detect this condition and default to a known state as described in this section.



Two counters are used to monitor the presence of the OSCCLK signal as shown in Figure 1-22. The first counter is incremented by the OSCCLK signal itself. When the PLL is not turned off, the second counter is incremented by the VCOCLK coming out of the PLL block. These counters are configured such that when the 7-bit OSCCLK counter overflows, it clears the 13-bit VCOCLK counter. In normal operating mode, as long as OSCCLK is present, the VCOCLK counter will never overflow.



Figure 1-22. Oscillator Logic Diagram

If the OSCCLK input signal is missing, then the PLL will output a default limp mode frequency and the VCOCLK counter will continue to increment. Since the OSCCLK signal is missing, the OSCCLK counter will not increment and, therefore, the VCOCLK counter is not periodically cleared. Eventually, the VCOCLK counter overflows and, if required, the device switches the CLKIN input to the CPU to the limp mode output frequency of the PLL.



When the VCOCLK counter overflows, the missing clock detection logic resets the CPU, peripherals, and other device logic. The reset generated is known as a missing clock detect logic reset (MCLKRS). The MCLKRS is an internal reset only. The external XRS pin of the device is not pulled low by MCLKRS and the PLLCR and PLLSTS registers are not reset. This is the default behavior at reset.

In addition to resetting the device, the missing oscillator logic sets the PLLSTS[MCLKSTS] register bit. When the MCLKCSTS bit is 1, this indicates that the missing oscillator detect logic has reset the part and that the CPU is now running at the limp mode frequency.

Software should check the PLLSTS[MCLKSTS] bit after a reset to determine if the device was reset by MCLKRS due to a missing clock condition. If MCLKSTS is set, then the firmware should take the action appropriate for the system such as a system shutdown. The missing clock status can be cleared by writing a 1 to the PLLSTS[MCLKCLR] bit. This will reset the missing clock detection circuits and counters. If OSCCLK is still missing after writing to the MCLKCLR bit, then the VCOCLK counter again overflows and the process will repeat.

**NOTE:** Applications in which the correct CPU operating frequency is absolutely critical should implement a mechanism by which the DSP will be held in reset should the input clocks ever fail. For example, an R-C circuit may be used to trigger the XRS pin of the DSP should the capacitor ever get fully charged. An I/O pin may be used to discharge the capacitor on a periodic basis to prevent it from getting fully charged. Such a circuit would also help in detecting failure of the flash memory.

The following precautions and limitations should be kept in mind:

- Use the proper procedure when changing the PLL Control Register. Always follow the procedure outlined in Figure 1-25 when modifying the PLLCR register.
- Do not write to the PLLCR register when the device is operating in limp mode. When writing to
  the PLLCR register, the device switches to the CPU's CLKIN input to OSCCLK/2. When operating after
  limp mode has been detected, OSCCLK may not be present and the clocks to the system will stop.
  Always check that the PLLSTS[MCLKSTS] bit = 0 before writing to the PLLCR register as described in
  Figure 1-25.
- Do not enter HALT low power mode when the device is operating in limp mode. If you try to enter HALT mode when the device is already operating in limp mode then the device may not properly enter HALT. The device may instead enter STANDBY mode or may hang and you may not be able to exit HALT mode. For this reason, always check that the PLLSTS[MCLKSTS] bit = 0 before entering HALT mode.

The following list describes the behavior of the missing clock detect logic in various operating modes:

# • PLL by-pass mode

When the PLL control register is set to 0x0000, the PLL is by-passed. Depending on the state of the PLLSTS[DIVSEL] bit, OSCCLK, OSCCLK/2, or OSCCLK/4 is connected directly to the CPU's input clock, CLKIN. If the OSCCLK is detected as missing, the device will automatically switch to the PLL, set the missing clock detect status bit, and generate a missing clock reset. The device will now run at the PLL limp mode frequency or one-half of the PLL limp mode frequency.

# • PLL enabled mode

When the PLL control register is non-zero (PLLCR = n, where  $n \neq 0x0000$ ), the PLL is enabled. In this mode, OSCCLK\*n, OSCCLK\*n/2, or OSCCLK\*n/4 is connected to CLKIN of the CPU. If OSCCLK is detected as missing, the missing clock detect status bit will be set and the device will generate a missing clock reset. The device will now run at one-half of the PLL limp mode frequency.



# • STANDBY low power mode

In this mode, the CLKIN to the CPU is stopped. If a missing input clock is detected, the missing clock status bit will be set and the device will generate a missing clock reset. If the PLL is in by-pass mode when this occurs, then one-half of the PLL limp frequency will automatically be routed to the CPU. The device will now run at the PLL limp mode frequency or at one-half or one-fourth of the PLL limp mode frequency, depending on the state of the PLLSTS[DIVSEL] bit.

# • HALT low power mode

In HALT low power mode, all of the clocks to the device are turned off. When the device comes out of HALT mode, the oscillator and PLL will power up. The counters that are used to detect a missing input clock (VCOCLK and OSCCLK) will be enabled only after this power-up has completed. If VCOCLK counter overflows, the missing clock detect status bit will be set and the device will generate a missing clock reset. If the PLL is in by-pass mode when the overflow occurs, then one-half of the PLL limp frequency will automatically be routed to the CPU. The device will now run at the PLL limp mode frequency or at one-half or one-fourth of the PLL limp mode frequency depending on the state of the PLLSTS[DIVSEL] bit.

# 1.2.2.6 NMI Interrupt and Watchdog

The NMI watchdog (NMIWD) is used to detect and aid in recovery from a clock failure condition. The NMI interrupt enables the monitoring of the erroneous CLOCKFAIL condition in the system. In this device, when a missing clock is detected, a missing-clock-reset (MCLKRS) is generated immediately. A CLOCKFAIL signal can also be generated first, which is then fed to the NMI Watchdog circuit and a reset is generated after a preprogrammed delay. This feature is not enabled upon power-up, however. That is, when the device first powers up, the MCLKRS signal is generated immediately upon clock failure. The user must enable the generation of the CLOCKFAIL signal via the CLKCTL[NMIRESETSEL] bit. Note that the NMI watchdog is different from the watchdog described in Section 1.2.4.

When the OSCCLK goes missing, the CLOCKFAIL signal triggers the NMI and gets the NMIWD counter running. In the NMI ISR, the application is expected to take corrective action (such as switch to an alternate clock source) and clear the CLOCKFAIL and NMIINT flags. If this is not done, the NMIWDCTR overflows and generates an NMI reset (NMIRS) after a pre-programmed number of SYSCLKOUT cycles. NMIRS is fed to MCLKRS to generate a system reset back into the core. The purpose of this is to allow software to gracefully shut down the system before a reset is generated. Note that NMI reset will not be reflected on the XRS pin and is internal to the device.

The CLOCKFAIL signal could also be used to activate the TZ5 signal to drive the PWM pins into a high impedance state. This allows the PWM outputs to be tripped in case of clock failure. Figure 1-23 shows the CLOCKFAIL interrupt mechanism.







A The NMI watchdog module is clocked by SYSCLKOUT. Due to the limp mode function of the PLL, SYSCLKOUT is present even if the source clock for OSCCLK fails.

The NMI Interrupt support registers are listed in Table 1-19.

| Table 1-19. NMI Interrupt Registers | Table 1-19. | <b>NMI Interrup</b> | t Registers |
|-------------------------------------|-------------|---------------------|-------------|
|-------------------------------------|-------------|---------------------|-------------|

| Name      | Address Range | Size (x16) | EALLOW | Description                   |
|-----------|---------------|------------|--------|-------------------------------|
| NMICFG    | 0x7060        | 1          | yes    | NMI Configuration Register    |
| NMIFLG    | 0x7061        | 1          | yes    | NMI Flag Register             |
| NMIFLGCLR | 0x7062        | 1          | yes    | NMI Flag Clear Register       |
| NMIFLGFRC | 0x7063        | 1          | yes    | NMI Flag Force Register       |
| NMIWDCNT  | 0x7064        | 1          | -      | NMI Watchdog Counter Register |
| NMIWDPRD  | 0x7065        | 1          | yes    | NMI Watchdog Period Register  |

| Bits | Name      | Туре | Description                                                                                                                                                                                                                                                                                                 |
|------|-----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:2 | reserved  |      |                                                                                                                                                                                                                                                                                                             |
| 1    | CLOCKFAIL |      | CLOCKFAIL-interrupt Enable Bit: This bit, when set to 1 enables the CLOCKFAIL condition to generate an NMI interrupt. Once enabled, the flag cannot be cleared by the user. Only a device reset clears the flag. Writes of 0 are ignored. Reading the bit will indicate if the flag is enabled or disabled: |
|      |           | 0    | CLOCKFAIL Interrupt Disabled                                                                                                                                                                                                                                                                                |
|      |           | 1    | CLOCKFAIL Interrupt Enabled                                                                                                                                                                                                                                                                                 |
| 0    | Reserved  |      |                                                                                                                                                                                                                                                                                                             |



| Bits | Name      | Туре | Description                                                                                                                                                                                             |
|------|-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:2 | Reserved  |      |                                                                                                                                                                                                         |
| 1    | CLOCKFAIL |      | CLOCKFAIL Interrupt Flag: This bit indicates if the CLOCKFAIL condition is latched. This bit can be cleared only by writing to the respective bit in the NMIFLGCLR register or by a device reset (XRS): |
|      |           | 0    | No CLOCKFAIL condition pending                                                                                                                                                                          |
|      |           | 1    | CLOCKFAIL condition detected. This bit will be set in the event of any clock failure.                                                                                                                   |
| 0    | NMIINT    |      | NMI Interrupt Flag: This bit indicates if an NMI interrupt was generated. This bit can only be cleared by writing to the respective bit in the NMIFLGCLR register or by an XRS reset:                   |
|      |           | 0    | No NMI interrupt generated                                                                                                                                                                              |
|      |           | 1    | NMI interrupt generated<br>No further NMI interrupts are generated until you clear this flag.                                                                                                           |

# Table 1-21. NMI Flag (NMIFLG) Register Bit Definitions (EALLOW Protected):

# Table 1-22. NMI Flag Clear (NMIFLGCLR) Register Bit Definitions (EALLOW Protected)

| Bits | Name                     | Туре | Description                                                                                 |
|------|--------------------------|------|---------------------------------------------------------------------------------------------|
| 15:2 | Reserved                 |      |                                                                                             |
| 1    | CLOCKFAIL <sup>(1)</sup> |      | CLOCKFAIL Flag Clear                                                                        |
|      |                          | 0    | Writes of 0 are ignored. Always reads back 0.                                               |
|      |                          | 1    | Writing a 1 to the respective bit clears the corresponding flag bit in the NMIFLG register. |
| 0    | NMIINT <sup>(1)</sup>    |      | NMI Flag Clear                                                                              |
|      |                          | 0    | Writes of 0 are ignored. Always reads back 0.                                               |
|      |                          | 1    | Writing a 1 to the respective bit clears the corresponding flag bit in the NMIFLG register. |

<sup>(1)</sup> If hardware is trying to set a bit to 1 while software is trying to clear a bit to 0 on the same cycle, hardware has priority. You should clear the pending CLOCKFAIL flag first and then clear the NMIINT flag.

# Table 1-23. NMI Flag Force (NMIFLGFRC) Register Bit Definitions (EALLOW Protected):

| Bits  | Name      | Value | Description                                                                                           |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------|
| 15:02 | Reserved  |       |                                                                                                       |
| 1     | CLOCKFAIL |       | CLOCKFAIL flag force                                                                                  |
|       |           | 0     | Writes of 0 are ignored. Always reads back 0. This can be used as a means to test the NMI mechanisms. |
|       |           | 1     | Writing a 1 sets the CLOCKFAIL flag.                                                                  |
| 0     | Reserved  |       |                                                                                                       |

# Table 1-24. NMI Watchdog Counter (NMIWDCNT) Register Bit Definitions

| Bits | Name     | Туре | Description                                                                                                                                                                                                                                                                                                                                                         |  |
|------|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15:0 | NMIWDCNT |      | NMI Watchdog Counter: This 16-bit incremental counter will start incrementing whenever any one of the enabled FAIL flags are set. If the counter reaches the period value, an NMIRS signal is fired, which then resets the system. The counter resets to zero when it reaches the period value and then restarts counting if any of the enabled FAIL flags are set. |  |
|      |          | 0    | If no enabled FAIL flag is set, then the counter resets to zero and remains at zero until an enabled FAIL flag is set.                                                                                                                                                                                                                                              |  |
|      |          | 1    | Normally, the software would respond to the NMI interrupt generated and clear the offending FLAG(s) before the NMI watchdog triggers a reset. In some situations, the software may decide to allow the watchdog to reset the device anyway.                                                                                                                         |  |
|      |          |      | The counter is clocked at the SYSCLKOUT rate. Reset value of this counter is zero.                                                                                                                                                                                                                                                                                  |  |

| Table 1-25. NMI Watchdog Period | (NMIWDPRD) Register | r Bit Definitions | EALLOW Protected |
|---------------------------------|---------------------|-------------------|------------------|
|                                 |                     |                   |                  |

| Bits | Name     | Туре | Description                                                                                                                                                                                                                                     |
|------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | NMIWDPRD | R/W  | NMI Watchdog Period: This 16-bit value contains the period value at which a reset is generated when the watchdog counter matches. At reset this value is set at the maximum. The software can decrease the period value at initialization time. |
|      |          |      | Writing a PERIOD value that is smaller then the current counter value automatically forces an NMIRS and resets the watchdog counter.                                                                                                            |

# 1.2.2.6.1 NMI Watchdog Emulation Considerations

The NMI watchdog module does not operate when trying to debug the target device (emulation suspend such as breakpoint). The NMI watchdog module behaves as follows under various debug conditions:

| CPU Suspended:                 | When the CPU is suspended, the NMI watchdog counter is suspended.                                                                                     |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Run-Free Mode:                 | When the CPU is placed in run-free mode, the NMI watchdog counter resumes operation as normal.                                                        |
| Real-Time Single-Step<br>Mode: | When the CPU is in real-time single-step mode, the NMI watchdog counter is suspended. The counter remains suspended even within real-time interrupts. |
| Real-Time Run-Free<br>Mode:    | When the CPU is in real-time run-free mode, the NMI watchdog counter operates as normal.                                                              |



#### 1.2.2.7 XCLKOUT Generation

The XCLKOUT signal is directly derived from the system clock SYSCLKOUT as shown in Figure 1-24. XCLKOUT can be either equal to, one-half, or one-fourth of SYSCLKOUT. By default, at power-up, XCLKOUT = SYSCLKOUT/4 or XCLKOUT = OSCCLK/16.





Default at reset

If XCLKOUT is not being used, it can be turned off by setting the XCLKOUTDIV bit to 3 in the XCLK register.

#### 1.2.2.8 PLL Control (PLLCR) Register

The PLLCR register is used to change the PLL multiplier of the device. Before writing to the PLLCR register, the following requirements must be met:

 The PLLSTS[DIVSEL] bit must be 0 (CLKIN divide by 4 enabled). Change PLLSTS[DIVSEL] only after the PLL has completed locking, i.e., after PLLSTS[PLLLOCKS] = 1.

Once the PLL is stable and has locked at the new specified frequency, the PLL switches CLKIN to the new value as shown in Table 1-26. When this happens, the PLLLOCKS bit in the PLLSTS register is set, indicating that the PLL has finished locking and the device is now running at the new frequency. User software can monitor the PLLLOCKS bit to determine when the PLL has completed locking. Once PLLSTS[PLLLOCKS] = 1, DIVSEL can be changed.

Follow the procedure in Figure 1-25 any time you are writing to the PLLCR register.









#### 1.2.2.9 PLL Control, Status and XCLKOUT Register Descriptions

The DIV field in the PLLCR register controls whether the PLL is bypassed or not and sets the PLL clocking ratio when it is not bypassed. PLL bypass is the default mode after reset. Do not write to the DIV field if the PLLSTS[DIVSEL] bit is 10 or 11, or if the PLL is operating in limp mode as indicated by the PLLSTS[MCLKSTS] bit being set. See the procedure for changing the PLLCR described in Figure 1-25.

#### Figure 1-26. PLLCR Register Layout

| 15 4     | 3 0   | ) |
|----------|-------|---|
| Reserved | DIV   |   |
| R-0      | R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-26. PLL Settings<sup>(1)</sup>

|                                 |                         | SYSCLKOUT (CLKIN) <sup>(2)</sup> |                    |
|---------------------------------|-------------------------|----------------------------------|--------------------|
| PLLCR[DIV] Value <sup>(3)</sup> | PLLSTS[DIVSEL] = 0 or 1 | PLLSTS[DIVSEL] = 2               | PLLSTS[DIVSEL] = 3 |
| 0000 (PLL bypass)               | OSCCLK/4 (Default)      | OSCCLK/2                         | OSCCLK/1           |
| 0001                            | (OSCCLK * 1)/4          | (OSCCLK * 1)/2                   | (OSCCLK * 1)/1     |
| 0010                            | (OSCCLK * 2)/4          | (OSCCLK * 2)/2                   | (OSCCLK * 2)/1     |
| 0011                            | (OSCCLK * 3)/4          | (OSCCLK * 3)/2                   | (OSCCLK * 3)/1     |
| 0100                            | (OSCCLK * 4)/4          | (OSCCLK * 4)/2                   | (OSCCLK * 4)/1     |
| 0101                            | (OSCCLK * 5)/4          | (OSCCLK * 5)/2                   | (OSCCLK * 5)/1     |
| 0110                            | (OSCCLK * 6)/4          | (OSCCLK * 6)/2                   | (OSCCLK * 6)/1     |
| 0111                            | (OSCCLK * 7)/4          | (OSCCLK * 7)/2                   | (OSCCLK * 7)/1     |
| 1000                            | (OSCCLK * 8)/4          | (OSCCLK * 8)/2                   | (OSCCLK * 8)/1     |
| 1001                            | (OSCCLK * 9)/4          | (OSCCLK * 9)/2                   | (OSCCLK * 9)/1     |
| 1010                            | (OSCCLK * 10)/4         | (OSCCLK * 10)/2                  | (OSCCLK * 10)/1    |
| 1011                            | (OSCCLK * 11)/4         | (OSCCLK * 11)/2                  | (OSCCLK * 11)/1    |
| 1100                            | (OSCCLK * 12)/4         | (OSCCLK * 12)/2                  | (OSCCLK * 12)/1    |
| 1101-1111                       | Reserved                | Reserved                         | Reserved           |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

(2) PLLSTS[DIVSEL] must be 0 or 1 before writing to the PLLCR and should be changed only after PLLSTS[PLLLOCKS] = 1. See Figure 1-25.

<sup>(3)</sup> The PLL control register (PLLCR) and PLL Status Register (PLLSTS) are reset to their default state by the XRS signal or a watchdog reset only. A reset issued by the debugger or the missing clock detect logic have no effect.

# Figure 1-27. PLL Status Register (PLLSTS)

| 15       | 14      |        |         |         |        | 9        | 8        |
|----------|---------|--------|---------|---------|--------|----------|----------|
| NORMRDYE |         | DIVSEL |         |         |        |          |          |
|          | R-0     |        |         |         |        |          | R/W-0    |
| 7        | 6       | 5      | 4       | 3       | 2      | 1        | 0        |
| DIVSEL   | MCLKOFF | OSCOFF | MCLKCLR | MCLKSTS | PLLOFF | Reserved | PLLLOCKS |
| R/W-0    | R/W-0   | R/W-0  | R/W-0   | R-0     | R/W-0  | R-0      | R-1      |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-27. PLL Status Register (PLLSTS) Field Descriptions

| Bits | Field    | Value | Description <sup>(1)</sup> <sup>(2)</sup>                                                                                                                                                                                                                          |  |
|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15   | NORMRDYE |       | NORMRDY Enable Bit: This bit selects if NORMRDY signal from VREG gates the PLL from turning<br>on when the VREG is out of regulation. It may be required to keep the PLL off while coming in and<br>out of HALT mode and this signal can be used for that purpose: |  |

(1) This register is reset to its default state only by the  $\overline{XRS}$  signal or a watchdog reset. It is not reset by a missing clock or debugger reset. (2) This register is EALLOW protected. See Section 1.4.2 for more information.



| Table 1-27. PLL Status Register (PLLSTS) Field Descriptions | s (continued) |
|-------------------------------------------------------------|---------------|
|-------------------------------------------------------------|---------------|

| Bits Field |          | Value  | Description <sup>(1)</sup> <sup>(2)</sup>                                                                                                                                                                                                                                                                                              |
|------------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          | 0      | NORMRDY signal from VREG does not gate PLL (PLL ignores NORMRDY)                                                                                                                                                                                                                                                                       |
|            |          | 1      | NORMRDY signal from VREG will gate PLL (PLL off when NORMRDY low)                                                                                                                                                                                                                                                                      |
|            |          |        | The NORMRDY signal from the VREG is low when the VREG is out of regulation and this signal will go high if the VREG is within regulation.                                                                                                                                                                                              |
| 14-9       | Reserved |        | Reserved                                                                                                                                                                                                                                                                                                                               |
| 8:7        | DIVSEL   |        | Divide Select: This bit selects between /4, /2, and /1 for CLKIN to the CPU. The configuration of the DIVSEL bit is as follows:                                                                                                                                                                                                        |
|            |          | 00, 01 | Select Divide By 4 for CLKIN                                                                                                                                                                                                                                                                                                           |
|            |          | 10     | Select Divide By 2 for CLKIN                                                                                                                                                                                                                                                                                                           |
|            |          | 11     | Select Divide By 1 for CLKIN. (This mode can be used only when PLL is off or bypassed.)                                                                                                                                                                                                                                                |
| 6          | MCLKOFF  |        | Missing clock-detect off bit                                                                                                                                                                                                                                                                                                           |
|            |          | 0      | Main oscillator fail-detect logic is enabled. (default)                                                                                                                                                                                                                                                                                |
|            |          | 1      | Main oscillator fail-detect logic is disabled and the PLL will not issue a limp-mode clock. Use this mode when code must not be affected by the detection circuit. For example, if external clocks are turned off.                                                                                                                     |
| 5          | OSCOFF   |        | Oscillator Clock Off Bit                                                                                                                                                                                                                                                                                                               |
|            |          | 0      | The OSCCLK signal from X1, X1/X2 or XCLKIN is fed to the PLL block. (default)                                                                                                                                                                                                                                                          |
|            |          | 1      | The OSCCLK signal from X1, X1/X2 or XCLKIN is not fed to the PLL block. This does not shut down the internal oscillator. The OSCOFF bit is used for testing the missing clock detection logic.                                                                                                                                         |
|            |          |        | When the OSCOFF bit is set, do not enter HALT or STANDBY modes or write to PLLCR as these operations can result in unpredictable behavior.                                                                                                                                                                                             |
|            |          |        | When the OSCOFF bit is set, the behavior of the watchdog is different depending on which input clock source (X1, X1/X2 or XCLKIN) is being used:                                                                                                                                                                                       |
|            |          |        | • X1 or X1/X2: The watchdog is not functional.                                                                                                                                                                                                                                                                                         |
|            |          |        | • XCLKIN: The watchdog is functional and should be disabled before setting OSCOFF.                                                                                                                                                                                                                                                     |
| 4          | MCLKCLR  |        | Missing Clock Clear Bit.                                                                                                                                                                                                                                                                                                               |
|            |          | 0      | Writing a 0 has no effect. This bit always reads 0.                                                                                                                                                                                                                                                                                    |
|            |          | 1      | Forces the missing clock detection circuits to be cleared and reset. If OSCCLK is still missing, the detection circuit will again generate a reset to the system, set the missing clock status bit (MCLKSTS), and the CPU will be powered by the PLL operating at a limp mode frequency.                                               |
| 3          | MCLKSTS  |        | Missing Clock Status Bit. Check the status of this bit after a reset to determine whether a missing oscillator condition was detected. Under normal conditions, this bit should be 0. Writes to this bit are ignored. This bit will be cleared by writing to the MCLKCLR bit or by forcing an external reset.                          |
|            |          | 0      | Indicates normal operation. A missing clock condition has not been detected.                                                                                                                                                                                                                                                           |
|            |          | 1      | Indicates that OSCCLK was detected as missing. The main oscillator fail detect logic has reset the device and the CPU is now clocked by the PLL operating at the limp mode frequency.                                                                                                                                                  |
|            |          |        | When the missing clock detection circuit automatically switches between OSCCLKSRC2 to OSCCLKSRC1 (upon detecting OSCCLKSRC2 failure), this bit will be automatically cleared and the missing clock detection circuit will be re-enabled. For all other cases, the user needs to re-enable this mode by writing a 1 to the MCLKCLR bit. |
| 2          | PLLOFF   |        | PLL Off Bit. This bit turns off the PLL. This is useful for system noise testing. This mode must only be used when the PLLCR register is set to 0x0000.                                                                                                                                                                                |
|            |          | 0      | PLL On (default)                                                                                                                                                                                                                                                                                                                       |
|            |          | 1      | PLL Off. While the PLLOFF bit is set the PLL module will be kept powered down.                                                                                                                                                                                                                                                         |
|            |          |        | The device must be in PLL bypass mode (PLLCR = 0x0000) before writing a 1 to PLLOFF. While the PLL is turned off (PLLOFF = 1), do not write a non-zero value to the PLLCR.                                                                                                                                                             |
|            |          |        | The STANDBY and HALT low power modes will work as expected when PLLOFF = 1. After waking up from HALT or STANDBY the PLL module will remain powered down.                                                                                                                                                                              |
| 1          | Reserved |        | Reserved                                                                                                                                                                                                                                                                                                                               |
| 0          | PLLLOCKS |        | PLL Lock Status Bit.                                                                                                                                                                                                                                                                                                                   |
|            |          | 0      | Indicates that the PLLCR register has been written to and the PLL is currently locking. The CPU is clocked by OSCCLK/2 until the PLL locks.                                                                                                                                                                                            |
|            |          | 1      | Indicates that the PLL has finished locking and is now stable.                                                                                                                                                                                                                                                                         |



Clocking

www.ti.com

0

# Figure 1-28. PLL Lock Period (PLLLOCKPRD) Register

15

PLLLOCKPRD

#### R/W-FFFFh

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-28. PLL Lock Period (PLLLOCKPRD) Register Field Descriptions

| Bit  | Field      | Value | Description <sup>(1)</sup> <sup>(2)</sup>                                                                                                                                                                                                                               |  |
|------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15:0 | PLLLOCKPRD |       | PLL Lock Counter Period Value                                                                                                                                                                                                                                           |  |
|      |            |       | These 16-bits select the PLL lock counter period. This value is programmable, so shorter PLL lock-<br>time can be programmed by user. The user needs to compute the number of OSCCLK cycles<br>(based on the OSCCLK value used in the design) and update this register. |  |
|      |            |       | PLL Lock Period                                                                                                                                                                                                                                                         |  |
|      |            | FFFFh | 65535 OSCLK Cycles (default on reset)                                                                                                                                                                                                                                   |  |
|      |            | FFFEh | 65534 OSCLK Cycles                                                                                                                                                                                                                                                      |  |
|      |            |       |                                                                                                                                                                                                                                                                         |  |
|      |            | 0001h | 1 OSCCLK Cycles                                                                                                                                                                                                                                                         |  |
|      |            | 0000h | 0 OSCCLK Cycles (no PLL lock period)                                                                                                                                                                                                                                    |  |

<sup>(1)</sup> PLLLOCKPRD is affected by XRSn signal only.

<sup>(2)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

# 1.2.2.10 External Reference Oscillator Clock Option

TI recommends that customers have the resonator/crystal vendor characterize the operation of their device with the DSP chip. The resonator/crystal vendor has the equipment and expertise to tune the tank circuit. The vendor can also advise the customer regarding the proper tank component values to provide proper start-up and stability over the entire operating range.

# 1.2.3 Low-Power Modes Block

Table 1-29 summarizes the various modes.

The various low-power modes operate as shown in Table 1-30.

See the TMS320F28055, TMS320F28054, TMS320F28053, TMS320F28052, TMS320F28051, TMS320F28050 Piccolo Microcontrollers Data Manual (literature number <u>SPRS797</u>) for exact timing for entering and exiting the low power modes.

|  | Table 1-2 | 9. Low-F | Power Mo | de Summary |
|--|-----------|----------|----------|------------|
|--|-----------|----------|----------|------------|

| Mode    | LPMCR0[1:0] | OSCCLK                                                             | CLKIN | SYSCLKOUT | Exit <sup>(1)</sup>                                                           |
|---------|-------------|--------------------------------------------------------------------|-------|-----------|-------------------------------------------------------------------------------|
| IDLE    | 00          | On                                                                 | On    | On        | XRS,<br>Watchdog interrupt,<br>Any enabled interrupt                          |
| STANDBY | 01          | On<br>(watchdog still running)                                     | Off   | Off       | XRS,<br>Watchdog interrupt,<br>GPIO Port A signal,<br>Debugger <sup>(2)</sup> |
| HALT    | 1X          | Off<br>(oscillator and PLL turned off,<br>watchdog not functional) | Off   | Off       | XRS,<br>GPIO Port A Signal,<br>Debugger <sup>(2)</sup>                        |

(1) The Exit column lists which signals or under what conditions the low power mode is exited. This signal must be kept low long enough for an interrupt to be recognized by the device. Otherwise the IDLE mode is not exited and the device goes back into the indicated low power mode.

<sup>(2)</sup> On the 28x, the JTAG port can still function even if the clock to the CPU (CLKIN) is turned off.

#### Table 1-30. Low Power Modes

| Mode                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| IDLE<br>Mode:<br>STANDBY<br>Mode: | This mode is exited by any enabled interrupt. The LPM block itself performs no tasks during this mode.                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|                                   | If the LPM bits in the LPMCR0 register are set to 01, the device enters STANDBY mode when the IDLE instruction is executed. In STANDBY mode the clock input to the CPU (CLKIN) is disabled, which disables all clocks derived from SYSCLKOUT. The oscillator and PLL and watchdog will still function. Before entering the STANDBY mode, you should perform the following tasks:                                                                               |  |  |  |  |
|                                   | <ul> <li>Enable the WAKEINT interrupt in the PIE module. This interrupt is connected to both the watchdog and the low power mode module interrupt.</li> </ul>                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|                                   | <ul> <li>If desired, specify one of the GPIO port A signals to wake the device in the GPIOLPMSEL register. The GPIOLPMSEL register is part of the GPIO module. In addition to the selected GPIO signal, the XRS input and the watchdog interrupt, if enabled in the LPMCR0 register, can wake the device from the STANDBY mode.</li> <li>Select the input qualification in the LPMCR0 register for the signal that will wake the device.</li> </ul>            |  |  |  |  |
|                                   | When the selected external signal goes low, it must remain low a number of OSCCLK cycles as specified by the<br>qualification period in the LPMCR0 register. If the signal should be sampled high during this time, the qualification will<br>restart. At the end of the qualification period, the PLL enables the CLKIN to the CPU and the WAKEINT interrupt is<br>latched in the PIE block. The CPU then responds to the WAKEINT interrupt if it is enabled. |  |  |  |  |



| Mode<br>HALT<br>Mode: | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                       | If the LPM bits in the LPMCR0 register are set to 1x, the device enters the HALT mode when the IDLE instruction is executed. In HALT mode all of the device clocks, including the PLL and oscillator, are shut down. Before entering the HALT mode, you should perform the following tasks:                                                                                                                                                                              |  |  |  |  |
|                       | <ul> <li>Enable the WAKEINT interrupt in the PIE module (PIEIER1.8 = 1). This interrupt is connected to both the<br/>watchdog and the Low-Power-Mode module interrupt.</li> </ul>                                                                                                                                                                                                                                                                                        |  |  |  |  |
|                       | <ul> <li>Specify one of the GPIO port A signals to wake the device in the GPIOLPMSEL register. The GPIOLPMSEL register is part of the GPIO module. In addition to the selected GPIO signal, the XRS input can also wake the device from the HALT mode.</li> </ul>                                                                                                                                                                                                        |  |  |  |  |
|                       | <ul> <li>Disable all interrupts with the possible exception of the HALT mode wakeup interrupt. The interrupts can be re-<br/>enabled after the device is brought out of HALT mode.</li> </ul>                                                                                                                                                                                                                                                                            |  |  |  |  |
|                       | 1. For device to exit HALT mode properly, the following conditions must be met:                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                       | Bit 7 (INT1.8) of PIEIER1 register should be 1.                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                       | Bit 0 (INT1) of IER register must be 1.                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|                       | 2. If the above conditions are met,                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|                       | <ul> <li>(a) WAKE_INT ISR will be executed first, followed by the instruction(s) after IDLE, if INTM =</li> <li>0.</li> </ul>                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                       | (b) WAKE_INT ISR will not be executed and instruction(s) after IDLE will be executed, if<br>INTM = 1.                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|                       | <b>Do not enter HALT low power mode when the device is operating in limp mode (PLLSTS[MCLKSTS] = 1).</b><br>If you try to enter HALT mode when the device is already operating in limp mode then the device may not properly enter<br>HALT. The device may instead enter STANDBY mode or may hang and you may not be able to exit HALT mode. For<br>this reason, always check that the PLLSTS[MCLKSTS] bit = 0 before entering HALT mode.                                |  |  |  |  |
|                       | When the selected external signal goes low, it is fed asynchronously to the LPM block. The oscillator is turned on and begins to power up. You must hold the signal low long enough for the oscillator to complete power up. When the signal is held low for enough time, this will asynchronously release the PLL and it will begin to lock. Once the PLL has locked, it feeds the CLKIN to the CPU at which time the CPU responds to the WAKEINT interrupt if enabled. |  |  |  |  |

#### Table 1-30. Low Power Modes (continued)

The low-power modes are controlled by the LPMCR0 register (Figure 1-29).

#### Figure 1-29. Low Power Mode Control 0 Register (LPMCR0)

| 15     | 14       |     | 8 | 7    | 2     | 1   | 0   |
|--------|----------|-----|---|------|-------|-----|-----|
| WDINTE | Reserved |     |   | QUAL | STDBY | LPM |     |
| R/W-0  |          | R-0 |   | R/W- | 0x3F  | R٨  | N-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

Clocking

# Table 1-31. Low Power Mode Control 0 Register (LPMCR0) Field Descriptions

| Bits | Field     | Value  | Description <sup>(1)</sup>                                                                                                                                                                                                                                              |
|------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | WDINTE    |        | Watchdog interrupt enable                                                                                                                                                                                                                                               |
|      |           | 0      | The watchdog interrupt is not allowed to wake the device from STANDBY. (default)                                                                                                                                                                                        |
|      |           | 1      | The watchdog is allowed to wake the device from STANDBY. The watchdog interrupt must also be enabled in the SCSR Register.                                                                                                                                              |
| 14-8 | Reserved  |        | Reserved                                                                                                                                                                                                                                                                |
| 7-2  | QUALSTDBY |        | Select number of OSCCLK clock cycles to qualify the selected GPIO inputs that wake the device from STANDBY mode. This qualification is only used when in STANDBY mode. The GPIO signals that can wake the device from STANDBY are specified in the GPIOLPMSEL register. |
|      |           | 000000 | 2 OSCCLKs                                                                                                                                                                                                                                                               |
|      |           | 000001 | 3 OSCCLKs                                                                                                                                                                                                                                                               |
|      |           |        |                                                                                                                                                                                                                                                                         |
|      |           | 111111 | 65 OSCCLKs (default)                                                                                                                                                                                                                                                    |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

#### Table 1-31. Low Power Mode Control 0 Register (LPMCR0) Field Descriptions (continued)

| Bits | Field                | Value | Description <sup>(1)</sup>                        |  |  |
|------|----------------------|-------|---------------------------------------------------|--|--|
| 1-0  | 0 LPM <sup>(2)</sup> |       | These bits set the low power mode for the device. |  |  |
|      |                      | 00    | Set the low power mode to IDLE (default)          |  |  |
|      |                      | 01    | Set the low power mode to STANDBY                 |  |  |
|      |                      | 10    | Set the low power mode to HALT                    |  |  |
|      |                      | 11    | Set the low power mode to HALT                    |  |  |

<sup>(2)</sup> The low power mode bits (LPM) only take effect when the IDLE instruction is executed. Therefore, you must set the LPM bits to the appropriate mode before executing the IDLE instruction.

# 1.2.3.1 Options for Automatic Wakeup in Low-power Modes

The device provides two options to automatically wake up from HALT and STANDBY modes, without the need for an external stimulus:

**Wakeup from HALT:** Set WDHALTI bit in CLKCTL register to 1. When the device wakes up from HALT, it will be through a CPU-watchdog reset. The WDFLAG bit in the WDCR register can be used to differentiate between a CPU-watchdog-reset and a device reset.

**Wakeup from STANDBY:** Set WDINTE bit in LPMCR0 register to 1. When the device wakes up from STANDBY, it will be through the WAKEINT interrupt (Interrupt 1.8 in the PIE).

#### Clocking

# 1.2.4 CPU Watchdog Block

The watchdog module generates an output pulse, 512 oscillator-clocks (OSCCLK) wide whenever the 8bit watchdog up counter has reached its maximum value. To prevent this, the user can either disable the counter or the software must periodically write a 0x55 + 0xAA sequence into the watchdog key register which resets the watchdog counter. Figure 1-30 shows the various functional blocks within the watchdog module.



A The WDRST and XRS signals are driven low for 512 OSCCLK cycles when a watchdog reset occurs. Likewise, if the watchdog interrupt is enabled, the WDINT signal will be driven low for 512 OSCCLK cycles when an interrupt occurs.

# 1.2.4.1 Servicing The Watchdog Timer

The WDCNTR is reset when the proper sequence is written to the WDKEY register before the 8-bit watchdog counter (WDCNTR) overflows. The WDCNTR is reset-enabled when a value of 0x55 is written to the WDKEY. When the next value written to the WDKEY register is 0xAA then the WDCNTR is reset. Any value written to the WDKEY other than 0x55 or 0xAA causes no action. Any sequence of 0x55 and 0xAA values can be written to the WDKEY without causing a system reset; only a write of 0x55 followed by a write of 0xAA to the WDKEY resets the WDCNTR.

| Step | Value Written to WDKEY | Result                                                                                           |
|------|------------------------|--------------------------------------------------------------------------------------------------|
| 1    | 0xAA                   | No action                                                                                        |
| 2    | 0xAA                   | No action                                                                                        |
| 3    | 0x55                   | WDCNTR is enabled to be reset if next value is 0xAA.                                             |
| 4    | 0x55                   | WDCNTR is enabled to be reset if next value is 0xAA.                                             |
| 5    | 0x55                   | WDCNTR is enabled to be reset if next value is 0xAA.                                             |
| 6    | 0xAA                   | WDCNTR is reset.                                                                                 |
| 7    | 0xAA                   | No action                                                                                        |
| 8    | 0x55                   | WDCNTR is enabled to be reset if next value is 0xAA.                                             |
| 9    | 0xAA                   | WDCNTR is reset.                                                                                 |
| 10   | 0x55                   | WDCNTR is enabled to be reset if next value is 0xAA.                                             |
| 11   | 0x32                   | Improper value written to WDKEY.<br>No action, WDCNTR no longer enabled to be reset by next 0xAA |
| 12   | 0xAA                   | No action due to previous invalid value.                                                         |
| 13   | 0x55                   | WDCNTR is enabled to be reset if next value is 0xAA.                                             |
| 14   | 0xAA                   | WDCNTR is reset.                                                                                 |

Step 3 in Table 1-32 is the first action that enables the WDCNTR to be reset. The WDCNTR is not actually reset until step 6. Step 8 again re-enables the WDCNTR to be reset and step 9 resets the WDCNTR. Step 10 again re-enables the WDCNTR ro be reset. Writing the wrong key value to the WDKEY in step 11 causes no action, however the WDCNTR is no longer enabled to be reset and the 0xAA in step 12 now has no effect.

If the watchdog is configured to reset the device, then a WDCR overflow or writing the incorrect value to the WDCR[WDCHK] bits will reset the device and set the watchdog flag (WDFLAG) in the WDCR register. After a reset, the program can read the state of this flag to determine the source of the reset. After reset, the WDFLAG should be cleared by software to allow the source of subsequent resets to be determined. Watchdog resets are not prevented when the flag is set.

# 1.2.4.2 Watchdog Reset or Watchdog Interrupt Mode

The watchdog can be configured in the SCSR register to either reset the device (WDRST) or assert an interrupt (WDINT) if the watchdog counter reaches its maximum value. The behavior of each condition is described below:

# Reset mode:

If the watchdog is configured to reset the device, then the  $\overline{\text{WDRST}}$  signal will pull the device reset (XRS) pin low for 512 OSCCLK cycles when the watchdog counter reaches its maximum value.

### • Interrupt mode:

If the watchdog is configured to assert an interrupt, then the WDINT signal will be driven low for 512 OSCCLK cycles, causing the WAKEINT interrupt in the PIE to be taken if it is enabled in the PIE module. The watchdog interrupt is edge triggered on the falling edge of WDINT. Thus, if the WAKEINT interrupt is re-enabled before WDINT goes inactive, you will not immediately get another interrupt. The next WAKEINT interrupt will occur at the next watchdog timeout.

If the watchdog is re-configured from interrupt mode to reset mode while WDINT is still active low, then the device will reset immediately. The WDINTS bit in the SCSR register can be read to determine the current state of the WDINT signal before reconfiguring the watchdog to reset mode.



#### 1.2.4.3 Watchdog Operation in Low Power Modes

In STANDBY mode, all of the clocks to the peripherals are turned off on the device. The only peripheral that remains functional is the watchdog since the watchdog module runs off the oscillator clock (OSCCLK). The WDINT signal is fed to the Low Power Modes (LPM) block so that it can be used to wake the device from STANDBY low power mode (if enabled). See the Low Power Modes Block section of the device data manual for details.

In IDLE mode, the watchdog interrupt (WDINT) signal can generate an interrupt to the CPU to take the CPU out of IDLE mode. The watchdog is connected to the WAKEINT interrupt in the PIE.

**NOTE:** If the watchdog interrupt is used to wake-up from an IDLE or STANDBY low power mode condition, then make sure that the WDINT signal goes back high again before attempting to go back into the IDLE or STANDBY mode. The WDINT signal will be held low for 512 OSCCLK cycles when the watchdog interrupt is generated. You can determine the current state of WDINT by reading the watchdog interrupt status bit (WDINTS) bit in the SCSR register. WDINTS follows the state of WDINT by two SYSCLKOUT cycles.

In HALT mode, this feature cannot be used because the oscillator (and PLL) are turned off and, therefore, so is the watchdog.

#### 1.2.4.4 Emulation Considerations

The watchdog module behaves as follows under various debug conditions:

| CPU Suspended:                 | When the CPU is suspended, the watchdog clock (WDCLK) is suspended                                                                                       |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Run-Free Mode:                 | When the CPU is placed in run-free mode, then the watchdog module resumes operation as normal.                                                           |
| Real-Time Single-Step<br>Mode: | When the CPU is in real-time single-step mode, the watchdog clock (WDCLK) is suspended. The watchdog remains suspended even within real-time interrupts. |
| Real-Time Run-Free<br>Mode:    | When the CPU is in real-time run-free mode, the watchdog operates as normal.                                                                             |

# 1.2.4.5 Watchdog Registers

The system control and status register (SCSR) contains the watchdog override bit and the watchdog interrupt enable/disable bit. Figure 1-31 describes the bit functions of the SCSR register.

#### Figure 1-31. System Control and Status Register (SCSR)

| 15 |          |          |        |         | 8          |
|----|----------|----------|--------|---------|------------|
|    |          | Reserved |        |         |            |
|    |          | R-0      |        |         |            |
| 7  |          | 3        | 2      | 1       | 0          |
|    | Reserved |          | WDINTS | WDENINT | WDOVERRIDE |
|    | R-0      |          | R-1    | R/W-0   | R/W1C-1    |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 1-33. System Control and Status Register (SCSR) Field Descriptions

| Bit  | Field      | Value | Description <sup>(1)</sup>                                                                                                                                                                                                                           |
|------|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-3 | Reserved   |       |                                                                                                                                                                                                                                                      |
| 2    | WDINTS     |       | Watchdog interrupt status bit. WDINTS reflects the current state of the $\overline{\text{WDINT}}$ signal from the watchdog block. WDINTS follows the state of $\overline{\text{WDINT}}$ by two SYSCLKOUT cycles.                                     |
|      |            |       | If the watchdog interrupt is used to wake the device from IDLE or STANDBY low power mode, use this bit to make sure WDINT is not active before attempting to go back into IDLE or STANDBY mode.                                                      |
|      |            | 0     | Watchdog interrupt signal (WDINT) is active.                                                                                                                                                                                                         |
|      |            | 1     | Watchdog interrupt signal (WDINT) is not active.                                                                                                                                                                                                     |
| 1    | WDENINT    |       | Watchdog interrupt enable.                                                                                                                                                                                                                           |
|      |            | 0     | The watchdog reset (WDRST) output signal is enabled and the watchdog interrupt (WDINT) output signal is disabled. This is the default state on reset (XRS). When the watchdog interrupt occurs the WDRST signal will stay low for 512 OSCCLK cycles. |
|      |            |       | If the WDENINT bit is cleared while $\overline{\text{WDINT}}$ is low, a reset will immediately occur. The WDINTS bit can be read to determine the state of the $\overline{\text{WDINT}}$ signal.                                                     |
|      |            | 1     | The $\overline{\text{WDRST}}$ output signal is disabled and the $\overline{\text{WDINT}}$ output signal is enabled. When the watchdog interrupt occurs, the $\overline{\text{WDINT}}$ signal will stay low for 512 OSCCLK cycles.                    |
|      |            |       | If the watchdog interrupt is used to wake the device from IDLE or STANDBY low power mode, use the WDINTS bit to make sure WDINT is not active before attempting to go back into IDLE or STANDBY mode.                                                |
| 0    | WDOVERRIDE |       | Watchdog override                                                                                                                                                                                                                                    |
|      |            | 0     | Writing a 0 has no effect. If this bit is cleared, it remains in this state until a reset occurs. The current state of this bit is readable by the user.                                                                                             |
|      |            | 1     | You can change the state of the watchdog disable (WDDIS) bit in the watchdog control (WDCR) register. If the WDOVERRIDE bit is cleared by writing a 1, you cannot modify the WDDIS bit.                                                              |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.



R-0

| ~ ' |         |   |
|-----|---------|---|
| 14  | ocking  | v |
|     | ισκιι π | 1 |
|     |         |   |

www.ti.com

|    | Figure 1-32. Watchdog | Counter Register (WDCNTR) |   |
|----|-----------------------|---------------------------|---|
| 15 | 8                     | 7                         | 0 |
|    | Reserved              | WDCNTR                    |   |

R-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-34. Watchdog Counter Register (WDCNTR) Field Descriptions

| Bits | Field    | Description                                                                                                                                                                                                                                                                                                                                                    |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                       |
| 7-0  | WDCNTR   | These bits contain the current value of the WD counter. The 8-bit counter continually increments at the watchdog clock (WDCLK), rate. If the counter overflows, then the watchdog initiates a reset. If the WDKEY register is written with a valid combination, then the counter is reset to zero. The watchdog clock rate is configured in the WDCR register. |

# Figure 1-33. Watchdog Reset Key Register (WDKEY)

| 15 8     | 7 0   |
|----------|-------|
| Reserved | WDKEY |
| R-0      | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 1-35. Watchdog Reset Key Register (WDKEY) Field Descriptions

| Bits | Field    | Value       | Description <sup>(1)</sup>                                                                                                                                                |
|------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved |             | Reserved                                                                                                                                                                  |
| 7-0  | WDKEY    |             | Refer to Table 1-32 for examples of different WDKEY write sequences.                                                                                                      |
|      |          | 0x55 + 0xAA | Writing 0x55 followed by 0xAA to WDKEY causes the WDCNTR bits to be cleared.                                                                                              |
|      |          | Other value | Writing any value other than 0x55 or 0xAA causes no action to be generated. If any value other than 0xAA is written after 0x55, then the sequence must restart with 0x55. |
|      |          |             | Reads from WDKEY return the value of the WDCR register.                                                                                                                   |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

# Figure 1-34. Watchdog Control Register (WDCR)

| 15      |       |   |       |       |   |       | 8 |
|---------|-------|---|-------|-------|---|-------|---|
|         |       |   | Rese  | erved |   |       |   |
| 7       | 6     | 5 |       | 3     | 2 |       | 0 |
| WDFLAG  | WDDIS |   | WDCHK |       |   | WDPS  |   |
| R/W1C-0 | R/W-0 |   | R/W-0 |       |   | R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 1-36. Watchdog Control Register (WDCR) Field Descriptions

| Bits | Field    | Value | Description <sup>(1)</sup>                                                                                                                                                          |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved |       | Reserved                                                                                                                                                                            |
| 7    | WDFLAG   |       | Watchdog reset status flag bit                                                                                                                                                      |
|      |          | 0     | The reset was caused either by the $\overline{\text{XRS}}$ pin or because of power-up. The bit remains latched until you write a 1 to clear the condition. Writes of 0 are ignored. |
|      |          | 1     | Indicates a watchdog reset (WDRST) generated the reset condition                                                                                                                    |
| 6    | WDDIS    |       | Watchdog disable. On reset, the watchdog module is enabled.                                                                                                                         |
|      |          | 0     | Enables the watchdog module. WDDIS can be modified only if the WDOVERRIDE bit in the SCSR register is set to 1. (default)                                                           |
|      |          | 1     | Disables the watchdog module.                                                                                                                                                       |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.



| Bits | Field | Value | Description <sup>(1)</sup>                                                                                                                                                                                                                                                                                                                         |
|------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5-3  | WDCHK |       | Watchdog check.                                                                                                                                                                                                                                                                                                                                    |
|      |       | 0,0,0 | You must ALWAYS write 1,0,1 to these bits whenever a write to this register is performed unless the intent is to reset the device via software.                                                                                                                                                                                                    |
|      |       | other | Writing any other value causes an immediate device reset or watchdog interrupt to be taken. Note that this happens even when watchdog module is disabled. Do not write to WDCHK bits when the watchdog module is disabled. These bits can be used to generate a software reset of the device. These three bits always read back as zero (0, 0, 0). |
| 2-0  | WDPS  |       | Watchdog pre-scale. These bits configure the watchdog counter clock (WDCLK) rate relative to OSCCLK/512:                                                                                                                                                                                                                                           |
|      |       | 000   | WDCLK = OSCCLK/512/1 (default)                                                                                                                                                                                                                                                                                                                     |
|      |       | 001   | WDCLK = OSCCLK/512/1                                                                                                                                                                                                                                                                                                                               |
|      |       | 010   | WDCLK = OSCCLK/512/2                                                                                                                                                                                                                                                                                                                               |
|      |       | 011   | WDCLK = OSCCLK/512/4                                                                                                                                                                                                                                                                                                                               |
|      |       | 100   | WDCLK = OSCCLK/512/8                                                                                                                                                                                                                                                                                                                               |
|      |       | 101   | WDCLK = OSCCLK/512/16                                                                                                                                                                                                                                                                                                                              |
|      |       | 110   | WDCLK = OSCCLK/512/32                                                                                                                                                                                                                                                                                                                              |
|      |       | 111   | WDCLK = OSCCLK/512/64                                                                                                                                                                                                                                                                                                                              |

### Table 1-36. Watchdog Control Register (WDCR) Field Descriptions (continued)

When the XRS line is low, the WDFLAG bit is forced low. The WDFLAG bit is only set if a rising edge on WDRST signal is detected (after synch and an 8192 SYSCLKOUT cycle delay) and the XRS signal is high. If the XRS signal is low when WDRST goes high, then the WDFLAG bit remains at 0. In a typical application, the WDRST signal connects to the XRS input. Hence to distinguish between a watchdog reset and an external device reset, an external reset must be longer in duration then the watchdog pulse.



Clocking

# 1.2.5 32-Bit CPU Timers 0/1/2

This section describes the three 32-bit CPU-timers (TIMER0/1/2) shown in (Figure 1-35).

The CPU Timer-0 and CPU-Timer 1 can be used in user applications. Timer 2 is reserved for DSP/BIOS. If the application is not using DSP/BIOS, then Timer 2 can be used in the application. The CPU-timer interrupt signals (TINT0, TINT1, TINT2) are connected as shown in Figure 1-36.



Figure 1-35. CPU-Timers

Figure 1-36. CPU-Timer Interrupts Signals and Output Signal



- A The timer registers are connected to the Memory Bus of the 28x processor.
- B The timing of the timers is synchronized to SYSCLKOUT of the processor clock.

The general operation of the CPU-timer is as follows: The 32-bit counter register TIMH:TIM is loaded with the value in the period register PRDH:PRD. The counter decrements once every (TPR[TDDRH:TDDR]+1) SYSCLKOUT cycles, where TDDRH:TDDR is the timer divider. When the counter reaches 0, a timer interrupt output signal generates an interrupt pulse. The registers listed in Table 1-37 are used to configure the timers.

| Name       | Address | Size (x16) | Description                         | Bit Description |
|------------|---------|------------|-------------------------------------|-----------------|
| TIMER0TIM  | 0x0C00  | 1          | CPU-Timer 0, Counter Register       | Figure 1-37     |
| TIMER0TIMH | 0x0C01  | 1          | CPU-Timer 0, Counter Register High  | Figure 1-38     |
| TIMER0PRD  | 0x0C02  | 1          | CPU-Timer 0, Period Register        | Figure 1-39     |
| TIMER0PRDH | 0x0C03  | 1          | CPU-Timer 0, Period Register High   | Figure 1-40     |
| TIMER0TCR  | 0x0C04  | 1          | CPU-Timer 0, Control Register       | Figure 1-41     |
| TIMER0TPR  | 0x0C06  | 1          | CPU-Timer 0, Prescale Register      | Figure 1-42     |
| TIMER0TPRH | 0x0C07  | 1          | CPU-Timer 0, Prescale Register High | Figure 1-43     |
| TIMER1TIM  | 0x0C08  | 1          | CPU-Timer 1, Counter Register       | Figure 1-37     |
| TIMER1TIMH | 0x0C09  | 1          | CPU-Timer 1, Counter Register High  | Figure 1-38     |
| TIMER1PRD  | 0x0C0A  | 1          | CPU-Timer 1, Period Register        | Figure 1-39     |
| TIMER1PRDH | 0x0C0B  | 1          | CPU-Timer 1, Period Register High   | Figure 1-40     |
| TIMER1TCR  | 0x0C0C  | 1          | CPU-Timer 1, Control Register       | Figure 1-41     |
| TIMER1TPR  | 0x0C0E  | 1          | CPU-Timer 1, Prescale Register      | Figure 1-42     |
| TIMER1TPRH | 0x0C0F  | 1          | CPU-Timer 1, Prescale Register High | Figure 1-43     |
| TIMER2TIM  | 0x0C10  | 1          | CPU-Timer 2, Counter Register       | Figure 1-37     |
| TIMER2TIMH | 0x0C11  | 1          | CPU-Timer 2, Counter Register High  | Figure 1-38     |
| TIMER2PRD  | 0x0C12  | 1          | CPU-Timer 2, Period Register        | Figure 1-39     |
| TIMER2PRDH | 0x0C13  | 1          | CPU-Timer 2, Period Register High   | Figure 1-40     |
| TIMER2TCR  | 0x0C14  | 1          | CPU-Timer 2, Control Register       | Figure 1-41     |
| TIMER2TPR  | 0x0C16  | 1          | CPU-Timer 2, Prescale Register      | Figure 1-42     |
| TIMER2TPRH | 0x0C17  | 1          | CPU-Timer 2, Prescale Register High | Figure 1-43     |

#### Table 1-37. CPU-Timers 0, 1, 2 Configuration and Control Registers

### Figure 1-37. TIMERxTIM Register (x = 1, 2, 3)

| 15    | 0 |
|-------|---|
| TIM   |   |
| R/W-0 |   |
|       |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-38. TIMERxTIM Register Field Descriptions

| Bits | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | TIM   | CPU-Timer Counter Registers (TIMH:TIM): The TIM register holds the low 16 bits of the current 32-bit count of the timer. The TIMH register holds the high 16 bits of the current 32-bit count of the timer. The TIMH:TIM decrements by one every (TDDRH:TDDR+1) clock cycles, where TDDRH:TDDR is the timer prescale divide-<br>down value. When the TIMH:TIM decrements to zero, the TIMH:TIM register is reloaded with the period value contained in the PRDH:PRD registers. The timer interrupt (TINT) signal is generated. |

## Figure 1-38. TIMERxTIMH Register (x = 1, 2, 3)

| 15    | 0 |
|-------|---|
| ТІМН  |   |
| R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

TEXAS

Clocking

## Table 1-39. TIMERxTIMH Register Field Descriptions

| Bits | Field | Description                    |
|------|-------|--------------------------------|
| 15-0 | ТІМН  | See description for TIMERxTIM. |

# Figure 1-39. TIMERxPRD Register (x = 1, 2, 3)

| 15 |       | 0 |
|----|-------|---|
|    | PRD   |   |
|    | R/W-1 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-40. TIMERxPRD Register Field Descriptions

| Bits | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 |       | CPU-Timer Period Registers (PRDH:PRD): The PRD register holds the low 16 bits of the 32-bit period. The PRDH register holds the high 16 bits of the 32-bit period. When the TIMH:TIM decrements to zero, the TIMH:TIM register is reloaded with the period value contained in the PRDH:PRD registers, at the start of the next timer input clock cycle (the output of the prescaler). The PRDH:PRD contents are also loaded into the TIMH:TIM when you set the timer reload bit (TRB) in the Timer Control Register (TCR). |

| Figure 1-40. TIMERxPRDH Register (x | ( = 1, 2, 3) |
|-------------------------------------|--------------|
|-------------------------------------|--------------|

| 15 |       | 0 |
|----|-------|---|
|    | PRDH  |   |
|    | R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 1-41. TIMERxPRDH Register Field Descriptions

| Bits | Field | Description                   |
|------|-------|-------------------------------|
| 15-0 | PRDH  | See description for TIMERxPRD |

| Figure 1-41. TIMERxTCR Register (x = 1, 2, 3) |          |       |          |             |      |          |   |
|-----------------------------------------------|----------|-------|----------|-------------|------|----------|---|
| 15                                            | 14       | 13    | 12       | 11          | 10   | 9        | 8 |
| TIF                                           | TIE      | Res   | Reserved |             | SOFT | Reserved |   |
| R/W-0                                         | R/W-0    | R     | -0       | R/W-0 R/W-0 |      | R-       | 0 |
| 7                                             | 6        | 5     | 4        | 3           |      |          | 0 |
| Res                                           | Reserved |       | TSS      | Reserved    |      |          |   |
| R-0                                           |          | R/W-0 | R/W-0    |             | R-0  | )        |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-42. TIMERxTCR Register Field Descriptions

| Bits  | Field    | Value | Description                                                                                                                   |
|-------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------|
| 15    | 15 TIF   |       | CPU-Timer Interrupt Flag.                                                                                                     |
|       |          | 0     | The CPU-Timer has not decremented to zero.                                                                                    |
|       |          |       | Writes of 0 are ignored.                                                                                                      |
|       |          | 1     | This flag gets set when the CPU-timer decrements to zero.                                                                     |
|       |          |       | Writing a 1 to this bit clears the flag.                                                                                      |
| 14    | TIE      |       | CPU-Timer Interrupt Enable.                                                                                                   |
|       |          | 0     | The CPU-Timer interrupt is disabled.                                                                                          |
|       |          | 1     | The CPU-Timer interrupt is enabled. If the timer decrements to zero, and TIE is set, the timer asserts its interrupt request. |
| 13-12 | Reserved |       | Reserved                                                                                                                      |



| Bits  | Field        | Value |      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11-10 | FREE<br>SOFT |       |      | CPU-Timer Emulation Modes: These bits are special emulation bits that determine the state of the timer when a breakpoint is encountered in the high-level language debugger. If the FREE bit is set to 1, then, upon a software breakpoint, the timer continues to run (that is, free runs). In this case, SOFT is a <i>don't care</i> . But if FREE is 0, then SOFT takes effect. In this case, if SOFT = 0, the timer halts the next time the TIMH:TIM decrements. If the SOFT bit is 1, then the timer halts when the TIMH:TIM has decremented to zero. |
|       |              | FREE  | SOFT | CPU-Timer Emulation Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |              | 0     | 0    | Stop after the next decrement of the TIMH:TIM (hard stop)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |              | 0     | 1    | Stop after the TIMH:TIM decrements to 0 (soft stop)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |              | 1     | 0    | Free run                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |              | 1     | 1    | Free run                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |              |       |      | In the SOFT STOP mode, the timer generates an interrupt before shutting down (since reaching 0 is the interrupt causing condition).                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 9-6   | Reserved     |       |      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5     | TRB          |       |      | CPU-Timer Reload bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |              | (     | C    | The TRB bit is always read as zero. Writes of 0 are ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       |              |       | 1    | When you write a 1 to TRB, the TIMH:TIM is loaded with the value in the PRDH:PRD, and the prescaler counter (PSCH:PSC) is loaded with the value in the timer divide-<br>down register (TDDRH:TDDR).                                                                                                                                                                                                                                                                                                                                                        |
| 4     | TSS          |       |      | CPU-Timer stop status bit. TSS is a 1-bit flag that stops or starts the CPU-timer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |              | (     | C    | Reads of 0 indicate the CPU-timer is running.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |              |       |      | To start or restart the CPU-timer, set TSS to 0. At reset, TSS is cleared to 0 and the CPU-timer immediately starts.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |              |       | 1    | Reads of 1 indicate that the CPU-timer is stopped.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |              |       |      | To stop the CPU-timer, set TSS to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3-0   | Reserved     |       |      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Table 1-42 | TIMERXTCR | Register | <b>Field Descri</b> | ptions | (continued) |
|------------|-----------|----------|---------------------|--------|-------------|
|            |           |          |                     |        |             |

# Figure 1-42. TIMERxTPR Register (x = 1, 2, 3)

| 15 8 | 7 0   |
|------|-------|
| PSC  | TDDR  |
| R-0  | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-43. TIMERxTPR Register Field Descriptions

| Bits | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | PSC   | CPU-Timer Prescale Counter. These bits hold the current prescale count for the timer. For every timer clock source cycle that the PSCH:PSC value is greater than 0, the PSCH:PSC decrements by one. One timer clock (output of the timer prescaler) cycle after the PSCH:PSC reaches 0, the PSCH:PSC is loaded with the contents of the TDDRH:TDDR, and the timer counter register (TIMH:TIM) decrements by one. The PSCH:PSC is also reloaded whenever the timer reload bit (TRB) is set by software. The PSCH:PSC can be checked by reading the register, but it cannot be set directly. It must get its value from the timer divide-down register (TDDRH:TDDR). At reset, the PSCH:PSC is set to 0. |
| 7-0  | TDDR  | CPU-Timer Divide-Down. Every (TDDRH:TDDR + 1) timer clock source cycles, the timer counter register (TIMH:TIM) decrements by one. At reset, the TDDRH:TDDR bits are cleared to 0. To increase the overall timer count by an integer factor, write this factor minus one to the TDDRH:TDDR bits. When the prescaler counter (PSCH:PSC) value is 0, one timer clock source cycle later, the contents of the TDDRH:TDDR reload the PSCH:PSC, and the TIMH:TIM decrements by one. TDDRH:TDDR also reloads the PSCH:PSC whenever the timer reload bit (TRB) is set by software.                                                                                                                             |



0

Clocking

# Figure 1-43. TIMERxTPRH Register (x = 1, 2, 3) 15 8 7

| PSCH | TDDRH |
|------|-------|
| R-0  | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-44. TIMERxTPRH Register Field Descriptions

| Bits | Field | Description                   |
|------|-------|-------------------------------|
| 15-8 | PSCH  | See description of TIMERxTPR. |
| 7-0  | TDDRH | See description of TIMERxTPR. |



# 1.3 General-Purpose Input/Output (GPIO)

The GPIO multiplexing (MUX) registers are used to select the operation of shared pins. The pins are named by their general purpose I/O name (i.e., GPIO0 - GPIO42). These pins can be individually selected to operate as digital I/O, referred to as GPIO, or connected to one of up to three peripheral I/O signals (via the GPxMUXn registers). If selected for digital I/O mode, registers are provided to configure the pin direction (via the GPxDIR registers). You can also qualify the input signals to remove unwanted noise (via the GPxQSELn, GPACTRL, and GPBCTRL registers).

# 1.3.1 GPIO Module Overview

Up to three independent peripheral signals are multiplexed on a single GPIO-enabled pin in addition to individual pin bit-I/O capability. There are three I/O ports. Port A consists of GPIO0-GPIO31, port B consists of GPIO32-GPIO42. Figure 1-44 shows the basic modes of operation for the GPIO module. Note that GPIO functionality is provided on JTAG pins as well.



General-Purpose Input/Output (GPIO)



Figure 1-44. GPIO0 to GPIO31 Multiplexing Diagram

A GPxDAT latch/read are accessed at the same memory location.





Figure 1-45. GPIO32 to GPIO40, GPIO42 Multiplexing Diagram

- A The GPIOINENCLK bit in the PCLKCR3 register does not affect the above GPIOs (I<sup>2</sup>C pins) since the pins are bidirectional.
- B The input qualification circuit is not reset when modes are changed (such as changing from output to input mode). Any state will get flushed by the circuit eventually.

# 1.3.1.1 JTAG Port

On this device, the JTAG port is reduced to 5 pins (TRST, TCK, TDI, TMS, TDO). TCK, TDI, TMS and TDO pins are also GPIO pins. The TRST signal selects either JTAG or GPIO operating mode for the pins in Figure 1-46.

**NOTE:** In these devices, the JTAG pins may also be used as GPIO pins. Care should be taken in the board design to ensure that the circuitry connected to these pins do not affect the emulation capabilities of the JTAG pin function. Any circuitry connected to these pins should not prevent the emulator from driving (or being driven by) the JTAG pins for successful debug.



General-Purpose Input/Output (GPIO)

# Figure 1-46. JTAG Port/GPIO Multiplexing



# 1.3.2 Configuration Overview

The pin function assignments, input qualification, and the external interrupt sources are all controlled by the GPIO configuration control registers. In addition, you can assign pins to wake the device from the HALT and STANDBY low power modes and enable/disable internal pullup resistors. Table 1-45 and Table 1-46 list the registers that are used to configure the GPIO pins to match the system requirements.

| Name <sup>(1)</sup>     | Address | Size (x16) | Register Description                               | Bit Description |
|-------------------------|---------|------------|----------------------------------------------------|-----------------|
| GPACTRL                 | 0x6F80  | 2          | GPIO A Control Register (GPIO0-GPIO31)             | Figure 1-52     |
| GPAQSEL1                | 0x6F82  | 2          | GPIO A Qualifier Select 1 Register (GPIO0-GPIO15)  | Figure 1-54     |
| GPAQSEL2                | 0x6F84  | 2          | GPIO A Qualifier Select 2 Register (GPIO16-GPIO31) | Figure 1-55     |
| GPAMUX1                 | 0x6F86  | 2          | GPIO A MUX 1 Register (GPIO0-GPIO15)               | Figure 1-49     |
| GPAMUX2                 | 0x6F88  | 2          | GPIO A MUX 2 Register (GPIO16-GPIO31)              | Figure 1-50     |
| GPADIR                  | 0x6F8A  | 2          | GPIO A Direction Register (GPIO0-GPIO31)           | Figure 1-57     |
| GPAPUD                  | 0x6F8C  | 2          | GPIO A Pull Up Disable Register (GPIO0-GPIO31)     | Figure 1-59     |
| GPBCTRL <sup>(2)</sup>  | 0x6F90  | 2          | GPIO B Control Register (GPIO32-GPIO42)            | Figure 1-53     |
| GPBQSEL1 <sup>(2)</sup> | 0x6F92  | 2          | GPIO B Qualifier Select 1 Register (GPIO32-GPIO42) | Figure 1-56     |
| GPBMUX1 <sup>(2)</sup>  | 0x6F96  | 2          | GPIO B MUX 1 Register (GPIO32-GPIO42)              | Figure 1-51     |
| GPBDIR <sup>(2)</sup>   | 0x6F9A  | 2          | GPIO B Direction Register (GPIO32-GPIO42)          |                 |
| GPBPUD <sup>(2)</sup>   | 0x6F9C  | 2          | GPIO B Pull Up Disable Register (GPIO32-GPIO42)    | Figure 1-60     |

#### **Table 1-45. GPIO Control Registers**

<sup>(1)</sup> The registers in this table are EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> GPIO41 does not exist on this device. The corresponding bits are reserved.

### Table 1-46. GPIO Interrupt and Low Power Mode Select Registers

| Name <sup>(1)</sup> | Address | Size<br>(x16) | Register Description                             | Bit Description |
|---------------------|---------|---------------|--------------------------------------------------|-----------------|
| GPIOXINT1SEL        | 0x6FE0  | 1             | XINT1 Source Select Register (GPIO0-GPIO31)      | Figure 1-65     |
| GPIOXINT2SEL        | 0x6FE1  | 1             | XINT2 Source Select Register (GPIO0-GPIO31)      | Figure 1-65     |
| GPIOXINT3SEL        | 0x6FE2  | 1             | XINT3 Source Select Register (GPIO0 - GPIO31)    | Figure 1-65     |
| GPIOLPMSEL          | 0x6FE8  | 1             | LPM wakeup Source Select Register (GPIO0-GPIO31) | Figure 8-14     |

<sup>(1)</sup> The registers in this table are EALLOW protected. See Section 1.4.2 for more information.



To plan configuration of the GPIO module, consider the following steps:

#### Step 1. Plan the device pin-out:

Through a pin multiplexing scheme, a lot of flexibility is provided for assigning functionality to the GPIO-capable pins. Before getting started, look at the peripheral options available for each pin, and plan pin-out for your specific system. Will the pin be used as a general purpose input or output (GPIO) or as one of up to three available peripheral functions? Knowing this information will help determine how to further configure the pin.

#### Step 2. Enable or disable internal pull-up resistors:

To enable or disable the internal pullup resistors, write to the respective bits in the GPIO pullup disable (GPAPUD and GPBPUD) registers. For pins that can function as ePWM output pins, the internal pullup resistors are disabled by default. All other GPIO-capable pins have the pullup enabled by default. The AIOx pins do not have internal pull-up resistors.

#### Step 3. Select input qualification:

If the pin will be used as an input, specify the required input qualification, if any. The input qualification is specified in the GPACTRL, GPBCTRL, GPAQSEL1, GPAQSEL2, GPBQSEL1, and GPBQSEL2 registers. By default, all of the input signals are synchronized to SYSCLKOUT only.

#### Step 4. Select the pin function:

Configure the GPxMUXn registers such that the pin is a GPIO or one of three available peripheral functions. By default, all GPIO-capable pins are configured at reset as general purpose input pins.

#### Step 5. For digital general purpose I/O, select the direction of the pin:

If the pin is configured as an GPIO, specify the direction of the pin as either input or output in the GPADIR, or GPBDIR registers. By default, all GPIO pins are inputs. To change the pin from input to output, first load the output latch with the value to be driven by writing the appropriate value to the GPxCLEAR, GPxSET, or GPxTOGGLE (or AIOCLEAR, AIOSET, or AIOTOGGLE) registers. Once the output latch is loaded, change the pin direction from input to output via the GPxDIR registers. The output latch for all pins is cleared at reset.

#### Step 6. Select low power mode wake-up sources:

Specify which pins, if any, will be able to wake the device from HALT and STANDBY low power modes. The pins are specified in the GPIOLPMSEL register.

### Step 7. Select external interrupt sources:

Specify the source for the XINT1 - XINT3 interrupts. For each interrupt you can specify one of the port A signals as the source. This is done by specifying the source in the GPIOXINTnSEL register. The polarity of the interrupts can be configured in the XINTnCR register as described in Section 1.5.6.

**NOTE:** There is a 2-SYSCLKOUT cycle delay from when a write to configuration registers such as GPxMUXn and GPxQSELn occurs to when the action is valid

# 1.3.3 Digital General Purpose I/O Control

For pins that are configured as GPIO you can change the values on the pins by using the registers in Table 1-47.

| Name                     | Address | Size (x16) | Register Description                   | Bit Description |
|--------------------------|---------|------------|----------------------------------------|-----------------|
| GPADAT                   | 0x6FC0  | 2          | GPIO A Data Register (GPIO0-GPIO31)    | Figure 1-61     |
| GPASET                   | 0x6FC2  | 2          | GPIO A Set Register (GPIO0-GPIO31)     | Figure 1-63     |
| GPACLEAR                 | 0x6FC4  | 2          | GPIO A Clear Register (GPIO0-GPIO31)   | Figure 1-63     |
| GPATOGGLE                | 0x6FC6  | 2          | GPIO A Toggle Register (GPIO0-GPIO31)  | Figure 1-63     |
| GPBDAT <sup>(1)</sup>    | 0x6FC8  | 2          | GPIO B Data Register (GPIO32-GPIO42)   | Figure 1-62     |
| GPBSET <sup>(1)</sup>    | 0x6FCA  | 2          | GPIO B Set Register (GPIO32-GPIO42)    | Figure 1-64     |
| GPBCLEAR <sup>(1)</sup>  | 0x6FCC  | 2          | GPIO B Clear Register (GPIO32-GPIO42)  | Figure 1-64     |
| GPBTOGGLE <sup>(1)</sup> | 0x6FCE  | 2          | GPIO B Toggle Register (GPIO32-GPIO42) | Figure 1-64     |

| Table | 1-47. | <b>GPIO</b> | Data | Registers |
|-------|-------|-------------|------|-----------|
|-------|-------|-------------|------|-----------|

<sup>(1)</sup> GPIO41 does not exist on this device.

# GPxDAT Registers

Each I/O port has one data register. Each bit in the data register corresponds to one GPIO pin. No matter how the pin is configured (GPIO or peripheral function), the corresponding bit in the data register reflects the current state of the pin after qualification. Writing to the GPxDAT/AIODAT register clears or sets the corresponding output latch and if the pin is enabled as a general purpose output (GPIO output) the pin will also be driven either low or high. If the pin is not configured as a GPIO output then the value will be latched, but the pin will not be driven. Only if the pin is later configured as a GPIO output, will the latched value be driven onto the pin.

When using the GPxDAT register to change the level of an output pin, you should be cautious not to accidentally change the level of another pin. For example, if you mean to change the output latch level of GPIOA1 by writing to the GPADAT register bit 0 using a read-modify-write instruction, a problem can occur if another I/O port A signal changes level between the read and the write stage of the instruction. Following is an analysis of why this happens:

The GPxDAT registers reflect the state of the pin, not the latch. This means the register reflects the actual pin value. However, there is a lag between when the register is written to when the new pin value is reflected back in the register. This may pose a problem when this register is used in subsequent program statements to alter the state of GPIO pins. An example is shown below where two program statements attempt to drive two different GPIO pins that are currently low to a high state.

If Read-Modify-Write operations are used on the GPxDAT registers, because of the delay between the output and the input of the first instruction (I1), the second instruction (I2) will read the old value and write it back.

GpioDataRegs.GPADAT.bit.GPIO1 = 1 ; I1 performs read-modifywrite of GPADAT GpioDataRegs.GPADAT.bit.GPIO2 = 1 ; I2 also a read-modifywrite of GPADAT. ; It gets the old value of GPIO1 due to the delay

The second instruction will wait for the first to finish its write due to the write-followed-by-read protection on this peripheral frame. There will be some lag, however, between the write of (I1) and the GPxDAT bit reflecting the new value (1) on the pin. During this lag, the second instruction will read the old value of GPIO1 (0) and write it back along with the new value of GPIO2 (1). Therefore, the GPIO1 pin stays low.

One solution is to put some NOP's between instructions. A better solution is to use the GPxSET/GPxCLEAR/GPxTOGGLE registers instead of the GPxDAT registers. These registers always read back a 0 and writes of 0 have no effect. Only bits that need to be changed can be specified without disturbing any other bit(s) that are currently in the process of changing.

### • GPxSET Registers

The set registers are used to drive specified GPIO pins high without disturbing other pins. Each I/O



port has one set register and each bit corresponds to one GPIO pin. The set registers always read back 0. If the corresponding pin is configured as an output, then writing a 1 to that bit in the set register will set the output latch high and the corresponding pin will be driven high. If the pin is not configured as a GPIO output, then the value will be latched but the pin will not be driven. Only if the pin is later configured as a GPIO output will the latched value will be driven onto the pin. Writing a 0 to any bit in the set registers has no effect.

# • GPxCLEAR Registers

The clear registers are used to drive specified GPIO pins low without disturbing other pins. Each I/O port has one clear register. The clear registers always read back 0. If the corresponding pin is configured as a general purpose output, then writing a 1 to the corresponding bit in the clear register will clear the output latch and the pin will be driven low. If the pin is not configured as a GPIO output, then the value will be latched but the pin will not be driven. Only if the pin is later configured as a GPIO output will the latched value will be driven onto the pin. Writing a 0 to any bit in the clear registers has no effect.

# • GPxTOGGLE Registers

The toggle registers are used to drive specified GPIO pins to the opposite level without disturbing other pins. Each I/O port has one toggle register. The toggle registers always read back 0. If the corresponding pin is configured as an output, then writing a 1 to that bit in the toggle register flips the output latch and pulls the corresponding pin in the opposite direction. That is, if the output pin is driven low, then writing a 1 to the corresponding bit in the toggle register will pull the pin high. Likewise, if the output pin is high, then writing a 1 to the corresponding bit in the toggle register will pull the pin high. Likewise, if the pin is not configured as a GPIO output, then the value will be latched but the pin will not be driven. Only if the pin is later configured as a GPIO output will the latched value will be driven onto the pin. Writing a 0 to any bit in the toggle registers has no effect.

# 1.3.4 Input Qualification

The input qualification scheme has been designed to be very flexible. You can select the type of input qualification for each GPIO pin by configuring the GPAQSEL1, GPAQSEL2, GPBQSEL1 and GPBQSEL2 registers. In the case of a GPIO input pin, the qualification can be specified as only synchronize to SYSCLKOUT or qualification by a sampling window. For pins that are configured as peripheral inputs, the input can also be asynchronous in addition to synchronized to SYSCLKOUT or qualified by a sampling window. The remainder of this section describes the options available.

# 1.3.4.1 No Synchronization (asynchronous input)

This mode is used for peripherals where input synchronization is not required or the peripheral itself performs the synchronization. Examples include communication ports SCI, SPI, eCAN, and I<sup>2</sup>C. In addition, it may be desirable to have the ePWM trip zone (TZn) signals function independent of the presence of SYSCLKOUT.

The asynchronous option is not valid if the pin is used as a general purpose digital input pin (GPIO). If the pin is configured as a GPIO input and the asynchronous option is selected then the qualification defaults to synchronization to SYSCLKOUT as described in Section 1.3.4.2.

# 1.3.4.2 Synchronization to SYSCLKOUT Only

This is the default qualification mode of all the pins at reset. In this mode, the input signal is only synchronized to the system clock (SYSCLKOUT). Because the incoming signal is asynchronous, it can take up to a SYSCLKOUT period of delay in order for the input to the DSP to be changed. No further qualification is performed on the signal.

# 1.3.4.3 Qualification Using a Sampling Window

In this mode, the signal is first synchronized to the system clock (SYSCLKOUT) and then qualified by a specified number of cycles before the input is allowed to change. Figure 1-47 and Figure 1-48 show how the input qualification is performed to eliminate unwanted noise. Two parameters are specified by the user for this type of qualification: 1) the sampling period, or how often the signal is sampled, and 2) the number of samples to be taken.







# Time between samples (sampling period):

To qualify the signal, the input signal is sampled at a regular period. The sampling period is specified by the user and determines the time duration between samples, or how often the signal will be sampled, relative to the CPU clock (SYSCLKOUT).

The sampling period is specified by the qualification period (QUALPRDn) bits in the GPxCTRL register. The sampling period is configurable in groups of 8 input signals. For example, GPIO0 to GPIO7 use GPACTRL[QUALPRD0] setting and GPIO8 to GPIO15 use GPACTRL[QUALPRD1]. Table 1-48 and Table 1-49 show the relationship between the sampling period or sampling frequency and the GPxCTRL[QUALPRDn] setting.



# Table 1-48. Sampling Period

|                          | eampning i enteu                                                |
|--------------------------|-----------------------------------------------------------------|
| If GPxCTRL[QUALPRDn] = 0 | 1 × T <sub>SYSCLKOUT</sub>                                      |
| If GPxCTRL[QUALPRDn] ≠ 0 | 2 × GPxCTRL[QUALPRDn] × T <sub>SYSCLKOUT</sub>                  |
|                          | Where T <sub>SYSCLKOUT</sub> is the period in time of SYSCLKOUT |

# Table 1-49. Sampling Frequency

#### Sampling Frequency

| If GPxCTRL[QUALPRDn] = 0 | f <sub>sysclkout</sub>                                     |
|--------------------------|------------------------------------------------------------|
| If GPxCTRL[QUALPRDn] ≠ 0 | f <sub>SYSCLKOUT</sub> × 1 ÷ (2 × GPxCTRL[QUALPRDn])       |
|                          | Where f <sub>SYSCLKOUT</sub> is the frequency of SYSCLKOUT |

From these equations, the minimum and maximum time between samples can be calculated for a given SYSCLKOUT frequency:

Example: Maximum Sampling Frequency

if GPxCTRL[QUALPRDn] = 0 then the sampling frequency is  $f_{SYSCLKOUT}$ If, for example,  $f_{SYSCLKOUT} = 60$  MHz then the signal will be sampled at 60 MHz or one sample every 17.67 ns.

```
Example: Minimum Sampling Frequency

if GPxCTRL[QUALPRDn] = 0xFF (that is, 255)

then the sampling frequency is f × 1÷ (2 x

GPxCTRL[QUALPRDn])

If, for example, f_{SYSCLKOUT} = 60 MHz

then the signal will be sampled at 60 MHz × 1÷ (2 × 255) or

one sample every 8.5 ns.
```

### Number of samples:

The number of times the signal is sampled is either three samples or six samples as specified in the qualification selection (GPAQSEL1, GPAQSEL2, GPBQSEL1, and GPBQSEL2) registers. When three or six consecutive cycles are the same, then the input change will be passed through to the DSP.

### **Total Sampling Window Width:**

The sampling window is the time during which the input signal will be sampled as shown in Figure 1-48. By using the equation for the sampling period along with the number of samples to be taken, the total width of the window can be determined.

For the input qualifier to detect a change in the input, the level of the signal must be stable for the duration of the sampling window width or longer.

The number of sampling periods within the window is always one less then the number of samples taken. For a thee-sample window, the sampling window width is 2 sampling periods wide where the sampling period is defined in Table 1-48. Likewise, for a six-sample window, the sampling window width is 5 sampling periods wide. Table 1-50 and Table 1-51 show the calculations that can be used to determine the total sampling window width based on GPxCTRL[QUALPRDn] and the number of samples taken.



## Table 1-50. Case 1: Three-Sample Sampling Window Width

## Total Sampling Window Width

| If GPxCTRL[QUALPRDn] = 0 | 2 × T <sub>SYSCLKOUT</sub>                               |
|--------------------------|----------------------------------------------------------|
| If GPxCTRL[QUALPRDn] ≠ 0 | 2 × 2 × GPxCTRL[QUALPRDn] × T <sub>SYSCLKOUT</sub>       |
|                          | Where $T_{SYSCLKOUT}$ is the period in time of SYSCLKOUT |

## Table 1-51. Case 2: Six-Sample Sampling Window Width

#### **Total Sampling Window Width**

| If GPxCTRL[QUALPRDn] = 0 | 5 × T <sub>SYSCLKOUT</sub>                               |
|--------------------------|----------------------------------------------------------|
| If GPxCTRL[QUALPRDn] ≠ 0 | 5 × 2 × GPxCTRL[QUALPRDn] × T <sub>SYSCLKOUT</sub>       |
|                          | Where $T_{SYSCLKOUT}$ is the period in time of SYSCLKOUT |

**NOTE:** The external signal change is asynchronous with respect to both the sampling period and SYSCLKOUT. Due to the asynchronous nature of the external signal, the input should be held stable for a time greater than the sampling window width to make sure the logic detects a change in the signal. The extra time required can be up to an additional sampling period +  $T_{SYSCLKOUT}$ .

The required duration for an input signal to be stable for the qualification logic to detect a change is described in the device specific data manual.



#### General-Purpose Input/Output (GPIO)

#### **Example Qualification Window:**

For the example shown in Figure 1-48, the input qualification has been configured as follows:

- GPxQSEL1/2 = 1,0. This indicates a six-sample qualification.
- GPxCTRL[QUALPRDn] = 1. The sampling period is  $t_w(SP) = 2 \times GPxCTRL[QUALPRDn] \times T_{SYSCLKOUT}$ .

This configuration results in the following:

- The width of the sampling window is: .
   t<sub>w</sub>(IQSW) = 5 × t<sub>w</sub>(SP) = 5 × 2 × GPxCTRL[QUALPRDn] × T<sub>SYSCLKOUT</sub> or 5 × 2 × T<sub>SYSCLKOUT</sub>
- If, for example,  $T_{SYSCLKOUT} = 16.67$  ns, then the duration of the sampling window is:  $t_w(IQSW) = 5 \times 2 \times 16.67$  ns =166.7 ns.
- To account for the asynchronous nature of the input relative to the sampling period and SYSCLKOUT, up to an additional sampling period, t<sub>w</sub>(SP), + T<sub>SYSCLKOUT</sub> may be required to detect a change in the input signal. For this example:

 $t_w(SP) + T_{SYSCLKOUT} = 333.4 \text{ ns} + 166.67 \text{ ns} = 500.1 \text{ ns}$ 

• In Figure 1-48, the glitch (A) is shorter then the qualification window and will be ignored by the input qualifier.



Figure 1-48. Input Qualifier Clock Cycles

- A. This glitch will be ignored by the input qualifier. The QUALPRD bit field specifies the qualification sampling period. It can vary from 00 to 0xFF. If QUALPRD = 00, then the sampling period is 1 SYSCLKOUT cycle. For any other value "n", the qualification sampling period in 2n SYSCLKOUT cycles (i.e., at every 2n SYSCLKOUT cycles, the GPIO pin will be sampled).
- B. The qualification period selected via the GPxCTRL register applies to groups of 8 GPIO pins.
- C. The qualification block can take either three or six samples. The GPxQSELn Register selects which sample mode is used.
- D. In the example shown, for the qualifier to detect the change, the input should be stable for 10 SYSCLKOUT cycles or greater. In other words, the inputs should be stable for (5 x QUALPRD x 2) SYSCLKOUT cycles. That would ensure 5 sampling periods for detection to occur. Since external signals are driven asynchronously, an 13-SYSCLKOUT-wide pulse ensures reliable recognition.



# 1.3.5 GPIO and Peripheral Multiplexing (MUX)

Up to three different peripheral functions are multiplexed along with a general input/output (GPIO) function per pin. This allows you to pick and choose a peripheral mix that will work best for the particular application.

and show an overview of the possible multiplexing combinations sorted by GPIO pin. The second column indicates the I/O name of the pin on the device. Since the I/O name is unique, it is the best way to identify a particular pin. Therefore, the register descriptions in this section only refer to the GPIO name of a particular pin. The MUX register and particular bits that control the selection for each pin are indicated in the first column.

For example, the multiplexing for the GPIO6 pin is controlled by writing to GPAMUX[13:12]. By writing to these bits, the pin is configured as either GPIO6, or one of up to three peripheral functions. The GPIO6 pin can be configured as follows:

| G[A,IX1[13:12] Bit Setting | Pin Functionality Selected      |
|----------------------------|---------------------------------|
| If GPAMUX1[13:12] = 0,0    | Pin configured as GPIO6         |
| If GPAMUX1[13:12] = 0,1    | Pin configured as EPWM4A (O)    |
| If GPAMUX1[13:12] = 1,0    | Pin configured as EPWMSYNCI (I) |
| If GPAMUX1[13:12] = 1,1    | Pin configured as EPWMSYNCO (O) |

These devices have different multiplexing schemes. If a peripheral is not available on a particular device, that MUX selection is reserved on that device and should not be used.

**NOTE:** If you should select a reserved GPIO MUX configuration that is not mapped to a peripheral, the state of the pin will be undefined and the pin may be driven. Reserved configurations are for future expansion and should not be selected. In the device MUX tables ( and ) these options are indicated as Reserved.

Some peripherals can be assigned to more than one pin via the MUX registers. For example, for this device, the SPISIMOA can be assigned to either the GPIO5 or GPIO16 pin, depending on individual system requirements as shown below:

| Pin      | Assigned to SPISIMOA | Mux Configuration    |
|----------|----------------------|----------------------|
| Choice 1 | GPIO5                | GPAMUX1[11:10] = 1,1 |
| Choice 2 | GPIO16               | GPAMUX2[1:0] = 1,1   |

If no pin is configured as an input to a peripheral, or if more than one pin is configured as an input for the same peripheral, then the input to the peripheral will either default to a 0 or a 1 as shown in Table 1-52. For example, if SPISIMOA were assigned to both GPIO5 and GPIO16, the input to the SPI peripheral would default to a high state as shown in Table 1-52 and the input would not be connected to GPIO5 or GPIO16.



#### General-Purpose Input/Output (GPIO)

www.ti.com

# Table 1-52. Default State of Peripheral Input

| Peripheral Input  | Description            | Default Input <sup>(1)</sup> |  |  |
|-------------------|------------------------|------------------------------|--|--|
| TZ1-TZ3           | Trip zone 1-3          | 1                            |  |  |
| EPWMSYNCI         | ePWM Synch Input       | 0                            |  |  |
| ECAP1             | eCAP1 input            | 1                            |  |  |
| EQEP1A            | eQEP input             | 1                            |  |  |
| EQEP1I            | eQEP index             | 1                            |  |  |
| EQEP1S            | eQEP strobe            | 1                            |  |  |
| SCIRXDA - SCIRXDC | SCI-A - SCI-C receive  | 1                            |  |  |
| CANRXA            | eCAN-A receive         | 1                            |  |  |
| SDAA              | l <sup>2</sup> C data  | 1                            |  |  |
| SCLA1             | l <sup>2</sup> C clock | 1                            |  |  |

<sup>(1)</sup> This value will be assigned to the peripheral input if more then one pin has been assigned to the peripheral function in the GPxMUX1/2 registers or if no pin has been assigned.

#### General-Purpose Input/Output (GPIO)

|                          | Default at Reset<br>Primary I/O<br>Function | Peripheral Selection         | Peripheral Selection 2 | Peripheral Selection 3   |  |  |
|--------------------------|---------------------------------------------|------------------------------|------------------------|--------------------------|--|--|
| GPAMUX1<br>Register Bits | (GPAMUX1 bits = 00)                         | (GPAMUX1 bits =<br>01)       | (GPAMUX1 bits = 10)    | (GPAMUX1 bits = 11)      |  |  |
| 1-0                      | GPIO0                                       | EPWM1A (O)                   | Reserved Reserved      |                          |  |  |
| 3-2                      | GPIO1                                       | EPWM1B (O)                   | Reserved               | CTRIPM1OUT (O)           |  |  |
| 5-4                      | GPIO2                                       | EPWM2A (O)                   | Reserved               | Reserved                 |  |  |
| 7-6                      | GPIO3                                       | EPWM2B (O)                   | SPISOMIA (I/O)         |                          |  |  |
| 9-8                      | GPIO4                                       | EPWM3A (O)                   | Reserved               | Reserved                 |  |  |
| 11-10                    | GPIO5                                       | EPWM3B (O)                   | SPISIMOA (I/O)         | ECAP1 (I/O)              |  |  |
| 13-12                    | GPIO6                                       | EPWM4A (O)                   | EPWMSYNCI (I)          | EPWMSYNCO (O)            |  |  |
| 15-14                    | GPIO7                                       | EPWM4B (O)                   | SCIRXDA (I)            | Reserved                 |  |  |
| 17-16                    | GPIO8                                       | EPWM5A (O)                   | Reserved               | ADCSOCAO (O)             |  |  |
| 19-18                    | GPIO9                                       | EPWM5B (O)                   | SCITXDB (O)            | Reserved                 |  |  |
| 21-20                    | GPIO10                                      | EPWM6A (O)                   | Reserved               | ADCSOCBO (O)             |  |  |
| 23-22                    | GPIO11                                      | EPWM6B (O)                   | SCIRXDB (I)            | Reserved                 |  |  |
| 25-24                    | GPIO12                                      | TZ1 (I) /<br>CTRIPM1OUT(O)   | SCITXDA (O)            | Reserved                 |  |  |
| 27-26                    | GPIO13                                      | TZ2 (I)                      | Reserved               |                          |  |  |
| 29-28                    | GPIO14                                      | TZ3 (I) /<br>CTRIPPFCOUT (O) | Reserved               |                          |  |  |
| 31-30                    | GPIO15                                      | TZ1 (I) /<br>CTRIPM1OUT(O)   | SCIRXDB (I)            | Reserved                 |  |  |
| GPAMUX2<br>Register Bits | (GPAMUX2 bits =<br>00)                      | (GPAMUX2 bits =<br>01)       | (GPAMUX2 bits = 10)    | (GPAMUX2 bits = 11)      |  |  |
| 1-0                      | GPIO16                                      | SPISIMOA (I/O)               | EQEP1S (I/O)           | TZ2 (I)                  |  |  |
| 3-2                      | GPIO17                                      | SPISOMIA (I/O)               | EQEP1I (I/O)           | TZ3 (I) / CTRIPPFCOUT (O |  |  |
| 5-4                      | GPIO18                                      | SPICLKA (I/O)                | SCITXDB (O)            | XCLKOUT (O)              |  |  |
| 7-6                      | GPIO19/XCLKIN                               | SPISTEA (I/O)                | SCIRXDB (I)            | ECAP1 (I/O)              |  |  |
| 9-8                      | GPIO20                                      | EQEP1A (I)                   | EPWM7A(O)              | CTRIPM1OUT (O)           |  |  |
| 11-10                    | GPIO21                                      | EQEP1B (I)                   | EPWM7B (O)             |                          |  |  |
| 13-12                    | GPIO22                                      | EQEP1S (I/O)                 | Reserved               | SCITXDB (O)              |  |  |
| 15-14                    | GPIO23                                      | EQEP1I (I/O)                 | Reserved               | SCIRXDB (I)              |  |  |
| 17-16                    | GPIO24                                      | ECAP1 (I/O) EPWM7A(O)        |                        | Reserved                 |  |  |
| 19-18                    | GPIO25                                      | Reserved                     | Reserved               | Reserved                 |  |  |
| 21-20                    | GPIO26                                      | Reserved                     | SCIRXDC(O)             | Reserved                 |  |  |
| 23-22                    | GPIO27                                      | Reserved                     | SCITXDC(O)             | Reserved                 |  |  |
| 25-24                    | GPIO28                                      | SCIRXDA (I)                  | SDAA (I/OC)            | TZ2 (I)                  |  |  |
| 27-26                    | GPIO29                                      | SCITXDA (O)                  | SCLA (I/OC)            | TZ3 (I) / CTRIPPFCOUT(O) |  |  |
| 29-28                    | GPIO30                                      | CANRXA (I)                   | SCIRXDB(I)             | EPWM7A(O)                |  |  |
| 31-30                    | GPIO31                                      | CANTXA (O)                   | SCITXDB(I)             | EPWM7B(O)                |  |  |

Table 1-53. 2805x GPIOA MUX

# **NOTE:** The word Reserved means that there is no peripheral assigned to this GPxMUX1/2 register setting. Should it be selected, the state of the pin will be undefined and the pin may be driven. This selection is a reserved configuration for future expansion.



|                          | Default at Reset<br>Primary I/O Function | Peripheral Selection 1 | Peripheral Selection 2 | Peripheral Selection 3 |
|--------------------------|------------------------------------------|------------------------|------------------------|------------------------|
| GPBMUX1 Register<br>Bits | (GPBMUX1 bits = 00)                      | (GPBMUX1 bits = 01)    | (GPBMUX1 bits = 10)    | (GPBMUX1 bits = 11)    |
| 1-0                      | GPIO32                                   | SDAA (I/OC)            | EPWMSYNCI (I)          | EQEP1S (I/O)           |
| 3-2                      | GPIO33                                   | SCLA (I/OC)            | EPWMSYNCO (O)          | EQEP1I (I/0)           |
| 5-4                      | GPIO34                                   |                        | Reserved               | CTRIPPFCOUT (O)        |
| 7-6                      | GPIO35 (TDI)                             | Reserved               | Reserved               | Reserved               |
| 9-8                      | GPIO36 (TMS)                             | Reserved               | Reserved               | Reserved               |
| 11-10                    | GPIO37 (TDO)                             | Reserved               | Reserved               | Reserved               |
| 13-12                    | GPIO38/XCLKIN (TCK)                      | Reserved               | Reserved               | Reserved               |
| 15-14                    | GPIO39                                   | Reserved               | SCIRXDC (I)            | CTRIPPFCOUT (O)        |
| 17-16                    | GPIO40                                   | EPWM7A (O)             | Reserved               | Reserved               |
| 19-18                    | Reserved                                 | Reserved               | Reserved               | Reserved               |
| 21-20                    | GPIO42                                   | Reserved               | Reserved               | CTRIPM1OUT (O)         |
| 31-26                    | Reserved                                 | Reserved               | Reserved               | Reserved               |

# 1.3.6 Register Bit Definitions

|     |     |     |     | Fig    |             | J. GFI | FOIL  |             |       |        | ) Keyi | Slei  |               |       |     |       |  |
|-----|-----|-----|-----|--------|-------------|--------|-------|-------------|-------|--------|--------|-------|---------------|-------|-----|-------|--|
| 31  | 30  | 29  | 28  | 27     | 26          | 25     | 24    | 23          | 22    | 21     | 20     | 19    | 18            | 17    | 16  |       |  |
| GPI | O15 | GPI | 014 | GPIO13 |             | GPIO12 |       | GPIO11      |       | GPIO10 |        | GPIO9 |               | GPIO8 |     |       |  |
| RΛ  | N-0 | R/V | V-0 | R/\    | R/W-0 R/W-0 |        | V-0   | R/W-0 R/W-0 |       | V-0    | R/W-0  |       | R/W-0         |       |     |       |  |
| 15  | 14  | 13  | 12  | 11     | 10          | 9      | 8     | 7           | 6     | 5      | 4      | 3     | 2             | 1     | 0   |       |  |
| GP  | 107 | GP  | 106 | GP     | GPIO5 GPIO4 |        | 104   | GPIO3       |       | GPIO2  |        | GPIO1 |               | GPIO0 |     |       |  |
| R/\ | N-0 | R/V | V-0 | R/\    |             |        | R/W-0 |             | R/W-0 |        | R/W-0  |       | 0 R/W-0 R/W-0 |       | V-0 | R/W-0 |  |

# Figure 1-49. GPIO Port A MUX 1 (GPAMUX1) Register

LEGEND- R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-55. GPIO Port A Multiplexing 1 (GPAMUX1) Register Field Descriptions

| Bits  | Field  | Value | Description                                                                                                                                                                                                                                                                                                                                |
|-------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | GPIO15 |       | Configure the GPIO15 pin as:                                                                                                                                                                                                                                                                                                               |
|       |        | 00    | GPIO15 - General purpose input/output 15 (default) (I/O)                                                                                                                                                                                                                                                                                   |
|       |        | 01    | $\overline{121}$ - Trip Zone 1(I) / CTRIPM1OUT - Comparator 1 output (O) . The pin function for this option is based on the direction chosen in the GPADIR register. If the pin is configured as an input, then $\overline{121}$ function is chosen. If the pin as configured as an output, than the CTRIPM1OUT function is chosen.        |
|       |        | 10    | SCIRXDB- SCI-B receive (I)                                                                                                                                                                                                                                                                                                                 |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                   |
| 29-28 | GPIO14 |       | Configure the GPIO14 pin as:                                                                                                                                                                                                                                                                                                               |
|       |        | 00    | GPIO14 - General purpose I/O 14 (default) (I/O)                                                                                                                                                                                                                                                                                            |
|       |        | 01    | $\overline{TZ3}$ - Trip zone 3 (I) / CTRIPPFCOUT - Comparator 3 output (O). The pin function for this option is based on the direction chosen in the GPADIR register. If the pin is configured as an input, then the $\overline{TZ3}$ function is chosen. If the pins is configured as an output, then the CTRIPPFCOUT function is chosen. |
|       |        | 10    | SCITXDB - SCI-B Transmit (O)                                                                                                                                                                                                                                                                                                               |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                   |
| 27-26 | GPIO13 |       | Configure the GPIO13 pin as:                                                                                                                                                                                                                                                                                                               |
|       |        | 00    | GPIO13 - General purpose I/O 13 (default) (I/O)                                                                                                                                                                                                                                                                                            |
|       |        | 01    | $\overline{TZ2}$ - Trip zone 2 (I) / CTRIPM2OUT - Comparator 2 output (O). The pin function for this option is based on the direction chosen in the GPADIR register. If the pin is configured as an input, then the $\overline{TZ2}$ function is chosen. If the pins is configured as an output, then the CTRIPM2OUT function is chosen.   |
|       |        | 10    | Reserved                                                                                                                                                                                                                                                                                                                                   |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                   |
| 25-24 | GPIO12 |       | Configure the GPIO12 pin as:                                                                                                                                                                                                                                                                                                               |
|       |        | 00    | GPIO12 - General purpose I/O 12 (default) (I/O)                                                                                                                                                                                                                                                                                            |
|       |        | 01    | $\overline{TZ1}$ - Trip zone 1 (I) / CTRIPM1OUT - Comparator 1 output (O). The pin function for this option is based on the direction chosen in the GPADIR register. If the pin is configured as an input, then the $\overline{TZ1}$ function is chosen. If the pins is configured as an output, then the CTRIPM1OUT function is chosen.   |
|       |        | 10    | SCITXDA - SCI-A Transmit (O)                                                                                                                                                                                                                                                                                                               |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                   |
| 23-22 | GPIO11 |       | Configure the GPIO11 pin as:                                                                                                                                                                                                                                                                                                               |
|       |        | 00    | GPIO11 - General purpose I/O 11 (default) (I/O)                                                                                                                                                                                                                                                                                            |
|       |        | 01    | EPWM6B - ePWM 6 output B (O)                                                                                                                                                                                                                                                                                                               |
|       |        | 10    | SCIRXDB - SCI-B receive (I)                                                                                                                                                                                                                                                                                                                |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                   |



# Table 1-55. GPIO Port A Multiplexing 1 (GPAMUX1) Register Field Descriptions (continued)

|       | Field  | Value | Description                                       |
|-------|--------|-------|---------------------------------------------------|
| 21-20 | GPIO10 |       | Configure the GPIO10 pin as:                      |
|       |        | 00    | GPIO10 - General purpose I/O 10 (default) (I/O)   |
|       |        | 01    | EPWM6A - ePWM6 output A (O)                       |
|       |        | 10    | Reserved                                          |
|       |        | 11    | ADCSOCBO - ADC Start of conversion B (O)          |
| 19-18 | GPIO9  |       | Configure the GPIO9 pin as:                       |
|       |        | 00    | GPIO9 - General purpose I/O 9 (default) (I/O)     |
|       |        | 01    | EPWM5B - ePWM5 output B                           |
|       |        | 10    | SCITXDB - SCI-B transmit (O)                      |
|       |        | 11    | Reserved                                          |
| 17-16 | GPIO8  |       | Configure the GPIO8 pin as:                       |
|       |        | 00    | GPIO8 - General purpose I/O 8 (default) (I/O)     |
|       |        | 01    | EPWM5A - ePWM5 output A (O)                       |
|       |        | 10    | Reserved                                          |
|       |        | 11    | ADCSOCAO - ADC Start of conversion A              |
| 15-14 | GPIO7  |       | Configure the GPIO7 pin as:                       |
| 13-14 |        | 00    | GPIO7 - General purpose I/O 7 (default) (I/O)     |
|       |        | 00    | EPWM4B - ePWM4 output B (O)                       |
|       |        |       |                                                   |
|       |        | 10    | SCIRXDA (I) - SCI-A receive (I)<br>Reserved       |
| 40.40 |        | 11    |                                                   |
| 13-12 | GPIO6  |       | Configure the GPIO6 pin as:                       |
|       |        | 00    | GPIO6 - General purpose I/O 6 (default)           |
|       |        | 01    | EPWM4A - ePWM4 output A (O)                       |
|       |        | 10    | EPWMSYNCI - ePWM Synch-in (I)                     |
|       |        | 11    | EPWMSYNCO - ePWM Synch-out (O)                    |
| 11-10 | GPIO5  |       | Configure the GPIO5 pin as:                       |
|       |        | 00    | GPIO5 - General purpose I/O 5 (default) (I/O)     |
|       |        | 01    | EPWM3B - ePWM3 output B                           |
|       |        | 10    | SPISIMOA (I/O) - SPI-A Slave input/Master output  |
|       |        | 11    | ECAP1 - eCAP1 (I/O)                               |
| 9-8   | GPIO4  |       | Configure the GPIO4 pin as:                       |
|       |        | 00    | GPIO4 - General purpose I/O 4 (default) (I/O)     |
|       |        | 01    | EPWM3A - ePWM3 output A (O)                       |
|       |        | 10    | Reserved.                                         |
|       |        | 11    | Reserved.                                         |
| 7-6   | GPIO3  |       | Configure the GPIO3 pin as:                       |
|       |        | 00    | GPIO3 - General purpose I/O 3 (default) (I/O)     |
|       |        | 01    | EPWM2B - ePWM2 output B (O)                       |
|       |        | 10    | SPISOMIA (I/O) - SPI-A Slave output/Master input  |
|       |        | 11    | CTRIPM2OUT - Comparator 2 output                  |
| 5-4   | GPIO2  |       | Configure the GPIO2 pin as:                       |
|       |        | 00    | GPIO2 (I/O) General purpose I/O 2 (default) (I/O) |
|       |        | 01    | EPWM2A - ePWM2 output A (O)                       |
|       |        | 10    | Reserved.                                         |
|       |        |       | Reserved.                                         |

| Tau  | Table 1-55. GPIO Port A multiplexing T (GPAMOXT) Register Field Descriptions (continued) |       |                                               |  |  |  |  |
|------|------------------------------------------------------------------------------------------|-------|-----------------------------------------------|--|--|--|--|
| Bits | Field                                                                                    | Value | Description                                   |  |  |  |  |
| 3-2  | GPIO1                                                                                    |       | Configure the GPIO1 pin as:                   |  |  |  |  |
|      |                                                                                          | 00    | GPIO1 - General purpose I/O 1 (default) (I/O) |  |  |  |  |
|      |                                                                                          | 01    | EPWM1B - ePWM1 output B (O)                   |  |  |  |  |
|      |                                                                                          | 10    | Reserved                                      |  |  |  |  |
|      |                                                                                          | 11    | COMP1OUT (O) - Comparator 1 output            |  |  |  |  |
| 1-0  | GPIO0                                                                                    |       | Configure the GPIO0 pin as:                   |  |  |  |  |
|      |                                                                                          | 00    | GPIO0 - General purpose I/O 0 (default) (I/O) |  |  |  |  |
|      |                                                                                          | 01    | EPWM1A - ePWM1 output A (O)                   |  |  |  |  |
|      |                                                                                          | 10    | Reserved.                                     |  |  |  |  |
|      |                                                                                          | 11    | Reserved.                                     |  |  |  |  |

# Table 1-55 GPIO Port & Multiplexing 1 (GPAMIIX1) Register Field Descriptions (continued)

# Figure 1-50. GPIO Port A MUX 2 (GPAMUX2) Register

|      |     |     |     |     |     |     |     |     | •   |    | , 0 |     |     |     |     |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|-----|-----|-----|-----|-----|
| 31   | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21 | 20  | 19  | 18  | 17  | 16  |
| GPIC | D31 | GPI | O30 | GPI | O29 | GPI | O28 | GPI | 027 | GP | O26 | GPI | O25 | GPI | O24 |
| R/W  | V-0 | R/V | V-0 | R/V | V-0 | R/\ | V-0 | R/\ | V-0 | R/ | N-0 | R/\ | V-0 | R/V | V-0 |
| 15   | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5  | 4   | 3   | 2   | 1   | 0   |
| GPIC | D23 | GPI | O22 | GPI | O21 | GPI | O20 | GPI | O19 | GP | O18 | GPI | O17 | GPI | O16 |
| R/W  | V-0 | R/V | V-0 | R/V | V-0 | R/\ | V-0 | R/  | V-0 | R/ | N-0 | R/\ | V-0 | R/V | V-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-56. GPIO Port A MUX 2 (GPAMUX2) Register Field Descriptions

| Bits  | Field  | Value | Description <sup>(1)</sup>                                                                                                                                                                                                                                                                                                                     |
|-------|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | GPIO31 |       | Configure the GPIO31 pin as:                                                                                                                                                                                                                                                                                                                   |
|       |        | 00    | GPIO31 - General purpose I/O 31 (default) (I/O)                                                                                                                                                                                                                                                                                                |
|       |        | 01    | CANTXA - eCAN-A transmit (O)                                                                                                                                                                                                                                                                                                                   |
|       |        | 10    | SCITXDB - SCI-B transmit (O)                                                                                                                                                                                                                                                                                                                   |
|       |        | 11    | EPWM7B - ePWM 7 Output B (O)                                                                                                                                                                                                                                                                                                                   |
| 29-28 | GPIO30 |       | Configure the GPIO30 pin as:                                                                                                                                                                                                                                                                                                                   |
|       |        | 00    | GPIO30 (I/O) General purpose I/O 30 (default) (I/O)                                                                                                                                                                                                                                                                                            |
|       |        | 01    | CANRXA - eCAN-A receive (I)                                                                                                                                                                                                                                                                                                                    |
|       |        | 10    | SCIRXDB - SCI-B receive (I)                                                                                                                                                                                                                                                                                                                    |
|       |        | 11    | EPWM7A - ePWM7 Output A (O)                                                                                                                                                                                                                                                                                                                    |
| 27-26 | GPIO29 |       | Configure the GPIO29 pin as:                                                                                                                                                                                                                                                                                                                   |
|       |        | 00    | GPIO29 (I/O) General purpose I/O 29 (default) (I/O)                                                                                                                                                                                                                                                                                            |
|       |        | 01    | SCITXDA - SCI-A transmit. (O)                                                                                                                                                                                                                                                                                                                  |
|       |        | 10    | SCLA - I <sup>2</sup> C clock open drain bidirectional port (I/O)                                                                                                                                                                                                                                                                              |
|       |        | 11    | $\overline{TZ3}$ - Trip zone 3(I) / CTRIPMPFCOUT (O) - Comparator 3 output (O). The pin function for this option is based on the direction chosen in the GPADIR register. If the pin is configured as an input, then the $\overline{TZ3}$ function is chosen. If the pins is configured as an output, then the CTRIPPFCOUT function is chosen. |

<sup>(1)</sup> If reserved configurations are selected, then the state of the pin will be undefined and the pin may be driven. These selections are reserved for future expansion and should not be used.

# Table 1-56. GPIO Port A MUX 2 (GPAMUX2) Register Field Descriptions (continued)

| Bits  | Field  | Value | Description <sup>(1)</sup>                                                                                                                                                                                                                                                                                                               |
|-------|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25-24 | GPIO28 |       | Configure the GPIO28 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO28 (I/O) General purpose I/O 28 (default) (I/O)                                                                                                                                                                                                                                                                                      |
|       |        | 01    | SCIRXDA - SCI-A receive (I)                                                                                                                                                                                                                                                                                                              |
|       |        | 10    | SDAA - I <sup>2</sup> C data open drain bidirectional port (I/O)                                                                                                                                                                                                                                                                         |
|       |        | 11    | $\overline{TZ2}$ - Trip Zone 2 (I) / CTRIPM2OUT - Comparator 2 output (O). The pin function for this option is based on the direction chosen in the GPADIR register. If the pin is configured as an input, then the $\overline{TZ2}$ function is chosen. If the pins is configured as an output, than the CTRIPM2OUT function is chosen. |
| 23-22 | GPIO27 |       | Configure the GPIO27 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO27 - General purpose I/O 27 (default) (I/O)                                                                                                                                                                                                                                                                                          |
|       |        | 01    | Reserved                                                                                                                                                                                                                                                                                                                                 |
|       |        | 10    | SCITXDC - SC-C transmit (O)                                                                                                                                                                                                                                                                                                              |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                 |
| 21-20 | GPIO26 |       | Configure the GPIO26 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO26 - General purpose I/O 26 (default) (I/O)                                                                                                                                                                                                                                                                                          |
|       |        | 01    | Reserved                                                                                                                                                                                                                                                                                                                                 |
|       |        | 10    | SCIRXDC - SCI-C receive (I)                                                                                                                                                                                                                                                                                                              |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                 |
| 19-18 | GPIO25 |       | Configure the GPIO25 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO25 - General purpose I/O 25 (default) (I/O)                                                                                                                                                                                                                                                                                          |
|       |        | 01    | Reserved                                                                                                                                                                                                                                                                                                                                 |
|       |        | 10    | Reserved                                                                                                                                                                                                                                                                                                                                 |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                 |
| 17-16 | GPIO24 |       | Configure the GPIO24 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO24 - General purpose I/O 24 (default) (I/O)                                                                                                                                                                                                                                                                                          |
|       |        | 01    | ECAP1 - eCAP1 (I/O)                                                                                                                                                                                                                                                                                                                      |
|       |        | 10    | EPWM7A - ePWM7 Output A (O)                                                                                                                                                                                                                                                                                                              |
|       |        | 11    | Reserved                                                                                                                                                                                                                                                                                                                                 |
| 15-14 | GPIO23 |       | Configure the GPIO23 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO23 - General purpose I/O 23 (default) (I/O)                                                                                                                                                                                                                                                                                          |
|       |        | 01    | EQEP1I - eQEP1 index (I/O)                                                                                                                                                                                                                                                                                                               |
|       |        | 10    | Reserved                                                                                                                                                                                                                                                                                                                                 |
|       |        | 11    | SCIRXDB - SCI-B receive (I)                                                                                                                                                                                                                                                                                                              |
| 13-12 | GPIO22 |       | Configure the GPIO22 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO22 - General purpose I/O 22 (default) (I/O)                                                                                                                                                                                                                                                                                          |
|       |        | 01    | EQEP1S - eQEP1 strobe (I/O)                                                                                                                                                                                                                                                                                                              |
|       |        | 10    | Reserved                                                                                                                                                                                                                                                                                                                                 |
|       |        | 11    | SCITXDB - SCI-B receive (I)                                                                                                                                                                                                                                                                                                              |
| 11-10 | GPIO21 |       | Configure the GPIO21 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO21 - General purpose I/O 21 (default) (I/O)                                                                                                                                                                                                                                                                                          |
|       |        | 01    | EQEP1B - eQEP1 input B (I)                                                                                                                                                                                                                                                                                                               |
|       |        | 10    | EPWM7B - ePWM7 Output B (O)                                                                                                                                                                                                                                                                                                              |
|       |        | 11    | CTRIPM2OUT - Comparator 2 Output (O)                                                                                                                                                                                                                                                                                                     |
| 9-8   | GPIO20 |       | Configure the GPIO20 pin as:                                                                                                                                                                                                                                                                                                             |
|       |        | 00    | GPIO20 - General purpose I/O 22 (default) (I/O)                                                                                                                                                                                                                                                                                          |
|       |        | 01    | EQEP1A - eQEP1 input A (I)                                                                                                                                                                                                                                                                                                               |
|       |        | 10    | EPWM7A - ePWM7 Output A (O)                                                                                                                                                                                                                                                                                                              |
|       |        | 11    | CTRIPM1OUT - Comparator 1 output(O)                                                                                                                                                                                                                                                                                                      |

| Bits | Field         | Value | Description <sup>(1)</sup>                                                                                                                                                                                                                                                                                      |
|------|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-6  | GPIO19/XCLKIN |       | Configure the GPIO19 pin as:                                                                                                                                                                                                                                                                                    |
|      |               | 00    | GPIO19 - General purpose I/O 19 (default) (I/O)                                                                                                                                                                                                                                                                 |
|      |               | 01    | SPISTEA - SPI-A slave transmit enable (I/O)                                                                                                                                                                                                                                                                     |
|      |               | 10    | SCIRXDB- SCI-B receive (I)                                                                                                                                                                                                                                                                                      |
|      |               | 11    | ECAP1 - eCAP1 (I/O)                                                                                                                                                                                                                                                                                             |
| 5-4  | GPIO18        |       | Configure the GPIO18 pin as:                                                                                                                                                                                                                                                                                    |
|      |               | 00    | GPIO18 - General purpose I/O 18 (default) (I/O)                                                                                                                                                                                                                                                                 |
|      |               | 01    | SPICLKA - SPI-A clock (I/O)                                                                                                                                                                                                                                                                                     |
|      |               | 10    | SCITXDB - SCI-B transmit (O)                                                                                                                                                                                                                                                                                    |
|      |               | 11    | XCLKOUT (O) - External clock output                                                                                                                                                                                                                                                                             |
| 3-2  | GPIO17        |       | Configure the GPIO17 pin as:                                                                                                                                                                                                                                                                                    |
|      |               | 00    | GPIO17 - General purpose I/O 17 (default) (I/O)                                                                                                                                                                                                                                                                 |
|      |               | 01    | SPISOMIA - SPI-A slave output/master input (I/O)                                                                                                                                                                                                                                                                |
|      |               | 10    | EQEP1I - eQEP1 Index (I/O)                                                                                                                                                                                                                                                                                      |
|      |               | 11    | TZ3 - Trip Zone 3 (I) / CTRIPPFCOUT - Comparator 3 output (O). The pin function for this option is based on the direction chosen in the GPADIR register. If the pin is configured as an input, then the TZ3 function is chosen. If the pins is configured as an output, than the CTRIPPFCOUT function is chosen |
| 1-0  | GPIO16        |       | Configure the GPIO16 pin as:                                                                                                                                                                                                                                                                                    |
|      |               | 00    | GPIO16 - General purpose I/O 16 (default) (I/O)                                                                                                                                                                                                                                                                 |
|      |               | 01    | SPISIMOA - SPI-A slave-in, master-out (I/O)                                                                                                                                                                                                                                                                     |
|      |               | 10    | EQEP1S - eQEP1 strobe (I/O)                                                                                                                                                                                                                                                                                     |
|      |               | 11    | TZ2 - Trip Zone 2 (I) / CTRIPM2OUT - Comparator 2 output (O). The pin function for this option is based on the direction chosen in the GPADIR register. If the pin is configured as an input, then the TZ2 function is chosen. If the pins is configured as an output, than the CTRIPM2OUT function is chosen.  |

# Table 1-56. GPIO Port A MUX 2 (GPAMUX2) Register Field Descriptions (continued)

# Figure 1-51. GPIO Port B MUX 1 (GPBMUX1) Register

| 31  |             |    |                |       |        |       |        |       | 22     | 21  | 20  | 19   | 18    | 17  | 16  |
|-----|-------------|----|----------------|-------|--------|-------|--------|-------|--------|-----|-----|------|-------|-----|-----|
|     | Reserved    |    |                |       |        |       |        |       |        | GPI | O42 | Rese | erved | GPI | O40 |
|     | R-0         |    |                |       |        |       |        |       |        | R/\ | V-0 | R    | -0    | R/V | V-0 |
| 15  | 14          | 13 | 12             | 11    | 10     | 9     | 8      | 7     | 6      | 5   | 4   | 3    | 2     | 1   | 0   |
| GPI | O39         |    | 3/XCLKI<br>CK) | GPIO3 | 7(TDO) | GPIO3 | 6(TMS) | GPI03 | 5(TDI) | GPI | O34 | GPI  | O33   | GPI | O32 |
| R/V | R/W-0 R/W-0 |    |                |       | R/V    | V-0   | RΛ     | V-0   | R/V    | V-0 | R/V | V-0  |       |     |     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-57. GPIO Port B MUX 1 (GPBMUX1) Register Field Descriptions

| Bit   | Field    | Value | Description                                |  |  |  |
|-------|----------|-------|--------------------------------------------|--|--|--|
| 31:22 | Reserved |       | Reserved                                   |  |  |  |
| 21:20 | GPIO42   |       | Configure this pin as:                     |  |  |  |
|       |          | 00    | GPIO 42 - general purpose I/O 42 (default) |  |  |  |
|       |          | 01    | EPWM7B - ePWM7 Output B (O)                |  |  |  |
|       |          | 10    | SCITXDC - SCI-C transmit (O)               |  |  |  |
|       |          | 11    | CTRIPM1OUT- Comparator 1 output (O)        |  |  |  |
| 19-18 | Reserved |       | Reserved                                   |  |  |  |

# Table 1-57. GPIO Port B MUX 1 (GPBMUX1) Register Field Descriptions (continued)

| Bit   | Field                 | Value         | Description                                                                                                                                                                             |
|-------|-----------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16 | GPIO40 <sup>(1)</sup> |               | Configure this pin as:                                                                                                                                                                  |
|       |                       | 00            | GPIO 40 - general purpose I/O 40 (default)                                                                                                                                              |
|       |                       | 01            | EPWM7A (O) - ePWM7 output A (O)                                                                                                                                                         |
|       |                       | 10 or 11      | Reserved                                                                                                                                                                                |
| 15:14 | GPIO39                |               | Configure this pin as:                                                                                                                                                                  |
|       |                       | 00            | GPIO 39 - general purpose I/O 39 (default)                                                                                                                                              |
|       |                       | 01            | Reserved                                                                                                                                                                                |
|       |                       | 10            | SCIRXDC - SCI-C Receive (I)                                                                                                                                                             |
|       |                       | 11            | CTRIPPFCOUT - Comparator 3 Output (O)                                                                                                                                                   |
| 13:12 | GPIO38/XCLKI          |               | Configure this pin as:                                                                                                                                                                  |
|       | N (TCK)               | 00            | GPIO 38 - general purpose I/O 38 (default) If TRST = 1, JTAG TCK function is chosen for this pin. This pin can also be used to provide a clock from an external oscillator to the core. |
|       |                       | 01, 10, or 11 | Reserved                                                                                                                                                                                |
| 11:10 | GPIO37(TDO)           |               | Configure this pin as:                                                                                                                                                                  |
|       |                       | 00            | GPIO 37 - general purpose I/O 37 (default) If $\overline{\text{TRST}} = 1$ , JTAG TDO function is chosen for this pin.                                                                  |
|       |                       | 01, 10, or 11 | Reserved                                                                                                                                                                                |
| 9:8   | GPIO36(TMS)           |               | Configure this pin as:                                                                                                                                                                  |
|       |                       | 00            | GPIO 36 - general purpose I/O 36 (default) If $\overline{\text{TRST}} = 1$ , JTAG TMS function is chosen for this pin.                                                                  |
|       |                       | 01, 10, or 11 | Reserved                                                                                                                                                                                |
| 7:6   | GPIO35(TDI)           |               | Configure this pin as:                                                                                                                                                                  |
|       |                       | 00            | GPIO 35 - general purpose I/O 35 (default) If TRST = 1, JTAG TDI function is chosen for this pin.                                                                                       |
|       |                       | 01, 10, or 11 | Reserved                                                                                                                                                                                |
| 5:4   | GPIO34                |               | Configure this pin as:                                                                                                                                                                  |
|       |                       | 00            | GPIO 34 - general purpose I/O 34 (default)                                                                                                                                              |
|       |                       | 01            | CTRIPM2OUT - Comparator 2 output (O)                                                                                                                                                    |
|       |                       | 10            | Reserved                                                                                                                                                                                |
|       |                       | 11            | CTRIPPFCOUT - Comparator 3 output (O)                                                                                                                                                   |
| 3:2   | GPIO33                |               | Configure this pin as:                                                                                                                                                                  |
|       |                       | 00            | GPIO 33 - general purpose I/O 33 (default)                                                                                                                                              |
|       |                       | 01            | SCLA - I <sup>2</sup> C clock open drain bidirectional port (I/O)                                                                                                                       |
|       |                       | 10            | EPWMSYNCO - External ePWM sync pulse output (O)                                                                                                                                         |
|       |                       | 11            | EQEP1I - eQEP1 index (I/O)                                                                                                                                                              |
| 1:0   | GPIO32                |               | Configure this pin as:                                                                                                                                                                  |
|       |                       | 00            | GPIO 32 - general purpose I/O 32 (default)                                                                                                                                              |
|       |                       | 01            | SDAA - I <sup>2</sup> C data open drain bidirectional port (I/O)                                                                                                                        |
|       |                       | 10            | EPWMSYNCI - External ePWM sync pulse input (I)                                                                                                                                          |
|       |                       | 11            | EQEP1S - eQEP1 strobe (I/O)                                                                                                                                                             |

<sup>(1)</sup> GPIO41 does not exist on this device.



| /w.ti.com |                 |                |                  | General-Purpose Inp   | out/Output (Gl |
|-----------|-----------------|----------------|------------------|-----------------------|----------------|
|           | Figure 1-52. GP | IO Port A Qual | ification Contro | ol (GPACTRL) Register |                |
| 31        |                 | 24             | 23               |                       | 16             |
|           | QUALPRD3        |                |                  | QUALPRD2              |                |
|           | R/W-0           |                |                  | R/W-0                 |                |
| 15        |                 | 8              | 7                |                       | 0              |
|           | QUALPRD1        |                |                  | QUALPRD0              |                |
|           | R/W-0           |                |                  | R/W-0                 |                |

R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

The GPxCTRL registers specify the sampling period for input pins when configured for input qualification using a window of 3 or 6 samples. The sampling period is the amount of time between qualification samples relative to the period of SYSCLKOUT. The number of samples is specified in the GPxQSELn registers.

# Table 1-58. GPIO Port A Qualification Control (GPACTRL) Register Field Descriptions

| Bits  | Field    | Value | Description <sup>(1)</sup>                               |
|-------|----------|-------|----------------------------------------------------------|
| 31-24 | QUALPRD3 |       | Specifies the sampling period for pins GPIO24 to GPIO31. |
|       |          | 0x00  | Sampling Period = $T_{SYSCLKOUT}$ <sup>(2)</sup>         |
|       |          | 0x01  | Sampling Period = $2 \times T_{SYSCLKOUT}$               |
|       |          | 0x02  | Sampling Period = $4 \times T_{SYSCLKOUT}$               |
|       |          |       |                                                          |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>           |
| 23-16 | QUALPRD2 |       | Specifies the sampling period for pins GPIO16 to GPIO23. |
|       |          | 0x00  | Sampling Period = $T_{SYSCLKOUT}$ <sup>(2)</sup>         |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>             |
|       |          | 0x02  | Sampling Period = $4 \times T_{SYSCLKOUT}$               |
|       |          |       |                                                          |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>           |
| 15-8  | QUALPRD1 |       | Specifies the sampling period for pins GPIO8 to GPIO15.  |
|       |          | 0x00  | Sampling Period = $T_{SYSCLKOUT}$ <sup>(2)</sup>         |
|       |          | 0x01  | Sampling Period = $2 \times T_{SYSCLKOUT}$               |
|       |          | 0x02  | Sampling Period = 4 x T <sub>SYSCLKOUT</sub>             |
|       |          |       |                                                          |
|       |          | 0xFF  | Sampling Period = 510 × $T_{SYSCLKOUT}$                  |
| 7-0   | QUALPRD0 |       | Specifies the sampling period for pins GPIO0 to GPIO7.   |
|       |          | 0x00  | Sampling Period = $T_{SYSCLKOUT}$ <sup>(2)</sup>         |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>             |
|       |          | 0x02  | Sampling Period = 4 x T <sub>SYSCLKOUT</sub>             |
|       |          |       |                                                          |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>           |

(1) This register is EALLOW protected. See Section 1.4.2 for more information.

(2)  $T_{\mbox{syscl}\mbox{KOUT}}$  indicates the period of SYSCLKOUT.



#### General-Purpose Input/Output (GPIO)

| www.       | ti.com  |
|------------|---------|
| ** ** ** . | 0.00111 |

| Figure 1-53. GPIO Port B Qualification Control (GPBCTRL) Register |          |      |       |          |    |  |  |  |
|-------------------------------------------------------------------|----------|------|-------|----------|----|--|--|--|
| 31                                                                | -        |      |       |          | 16 |  |  |  |
|                                                                   |          | Rese | erved |          |    |  |  |  |
|                                                                   |          | R    | -0    |          |    |  |  |  |
| 15                                                                |          | 8    | 7     |          | 0  |  |  |  |
|                                                                   | QUALPRD1 |      |       | QUALPRD0 |    |  |  |  |
|                                                                   | R/W-0    |      | R/W-0 |          |    |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-59. GPIO Port B Qualification Control (GPBCTRL) Register Field Descriptions

| Bits  | Field    | Value | Description <sup>(1)</sup>                                             |
|-------|----------|-------|------------------------------------------------------------------------|
| 31-16 | Reserved |       | Reserved                                                               |
| 15-8  | QUALPRD1 |       | Specifies the sampling period for pins GPIO40 to GPIO42 <sup>(2)</sup> |
|       |          | 0x00  | Sampling Period = $T_{SYSCLKOUT}$ <sup>(3)</sup>                       |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>                           |
|       |          | 0x02  | Sampling Period = $4 \times T_{SYSCLKOUT}$                             |
|       |          |       |                                                                        |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>                         |
| 7-0   | QUALPRD0 |       | Specifies the sampling period for pins GPIO32 to GPIO 39               |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>                         |
|       |          | 0x00  | Sampling Period = $T_{SYSCLKOUT}$ <sup>(3)</sup>                       |
|       |          | 0x01  | Sampling Period = $2 \times T_{SYSCLKOUT}$                             |
|       |          | 0x02  | Sampling Period = $4 \times T_{SYSCLKOUT}$                             |
|       |          |       |                                                                        |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>                         |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> GPIO41 does not exist on this device.

 $^{(3)}$   $\ \ T_{SYSCLKOUT}$  indicates the period of SYSCLKOUT.

General-Purpose Input/Output (GPIO)

|     |     |     | Figu | re 1-54 | . GPIO | Port A      | Quali  | ication     | Select | t 1 (GP | AQSEL  | _1) Reg | jister |     |       |  |
|-----|-----|-----|------|---------|--------|-------------|--------|-------------|--------|---------|--------|---------|--------|-----|-------|--|
| 31  | 30  | 29  | 28   | 27      | 26     | 25          | 24     | 23          | 22     | 21      | 20     | 19      | 18     | 17  | 16    |  |
| GPI | 015 | GPI | O14  | GPI     | GPIO13 |             | GPIO12 |             | GPIO11 |         | GPIO10 |         | GPIO9  |     | GPIO8 |  |
| R/\ | N-0 | R/V | V-0  | RΛ      | N-0    | RΛ          | V-0    | R/V         | V-0    | R/      | N-0    | RΛ      | V-0    | R/V | V-0   |  |
| 15  | 14  | 13  | 12   | 11      | 10     | 9           | 8      | 7           | 6      | 5       | 4      | 3       | 2      | 1   | 0     |  |
| GP  | 107 | GP  | 106  | GP      | 105    | GP          | IO4    | GP          | IO3    | GP      | 102    | GP      | IO1    | GP  | 100   |  |
| R/\ | N-0 | R/V | V-0  | RΛ      | N-0    | R/W-0 R/W-0 |        | R/W-0 R/W-0 |        | R/W-0   |        |         |        |     |       |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-60. GPIO Port A Qualification Select 1 (GPAQSEL1) Register Field Descriptions

| Bits | Field        | Value | Description <sup>(1)</sup>                                                                                                                                                                                               |
|------|--------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO15-GPIO0 |       | Select input qualification type for GPIO0 to GPIO15. The input qualification of each GPIO input is controlled by two bits as shown in Figure 1-54.                                                                       |
|      |              | 00    | Synchronize to SYSCLKOUT only. Valid for both peripheral and GPIO pins.                                                                                                                                                  |
|      |              | 01    | Qualification using 3 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                |
|      |              | 10    | Qualification using 6 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                |
|      |              | 11    | Asynchronous. (no synchronization or qualification). This option applies to pins configured as peripherals only. If the pin is configured as a GPIO input, then this option is the same 0,0 or synchronize to SYSCLKOUT. |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

# Figure 1-55. GPIO Port A Qualification Select 2 (GPAQSEL2) Register

|         |     |     |     |     |     |        |     |        |     | •      |     | , ,    |     |     |     |
|---------|-----|-----|-----|-----|-----|--------|-----|--------|-----|--------|-----|--------|-----|-----|-----|
| 31      | 30  | 29  | 28  | 27  | 26  | 25     | 24  | 23     | 22  | 21     | 20  | 19     | 18  | 17  | 16  |
| GPI     | O31 | GPI | O30 | GPI | O29 | GPI    | O28 | GPI    | 027 | GPI    | O26 | GPI    | O25 | GPI | D24 |
| R/V     | V-0 | R/V | V-0 | R/V | V-0 | R/V    | V-0 | R/V    | V-0 | R/V    | V-0 | R/V    | V-0 | R/V | V-0 |
| 15      | 14  | 13  | 12  | 11  | 10  | 9      | 8   | 7      | 6   | 5      | 4   | 3      | 2   | 1   | 0   |
| GPI     | O23 | GPI | 022 | GPI | O21 | GPIO20 |     | GPIO19 |     | GPIO18 |     | GPIO17 |     | GPI | D16 |
| <br>R/V | V-0 | R/V | V-0 | R/V | V-0 | R/V    | V-0 | R/\    | V-0 | R/\    | V-0 | R/V    | V-0 | R/V | V-0 |
|         |     |     |     |     |     |        |     |        |     |        |     |        |     |     |     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-61. GPIO Port A Qualification Select 2 (GPAQSEL2) Register Field Descriptions

| Bits | Field         | Value | Description <sup>(1)</sup>                                                                                                                                                                                                  |
|------|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31-GPIO16 |       | Select input qualification type for GPIO16 to GPIO31. The input qualification of each GPIO input is controlled by two bits as shown in Figure 1-55.                                                                         |
|      |               | 00    | Synchronize to SYSCLKOUT only. Valid for both peripheral and GPIO pins.                                                                                                                                                     |
|      |               | 01    | Qualification using 3 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |               | 10    | Qualification using 6 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |               | 11    | Asynchronous. (no synchronization or qualification). This option applies to pins configured as peripherals only. If the pin is configured as a GPIO input, then this option is the same as 0,0 or synchronize to SYSCLKOUT. |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.



#### General-Purpose Input/Output (GPIO)

| Figure 1-56. GPIO Port B Qualification Select 1 (GPBQSEL1) Register |     |          |     |     |       |     |             |       |       |     |       |       |       |     |     |
|---------------------------------------------------------------------|-----|----------|-----|-----|-------|-----|-------------|-------|-------|-----|-------|-------|-------|-----|-----|
| 31                                                                  |     |          |     |     |       |     |             |       | 22    | 21  | 20    | 19    | 18    | 17  | 16  |
|                                                                     |     | Reserved |     |     |       |     |             |       |       | GP  | O42   | Rese  | erved | GPI | O40 |
|                                                                     | R-0 |          |     |     |       |     |             | R/W-0 |       | R-0 |       | R/W-0 |       |     |     |
| 15                                                                  | 14  | 13       | 12  | 11  | 10    | 9   | 8           | 7     | 6     | 5   | 4     | 3     | 2     | 1   | 0   |
| GPI                                                                 | O39 | GPI      | O38 | GPI | O37   | GPI | O36         | GPI   | O35   | GP  | O34   | GPI   | O33   | GPI | O32 |
| R/V                                                                 | V-0 | R/V      | V-0 | R/\ | R/W-0 |     | R/W-0 R/W-0 |       | R/W-0 |     | R/W-0 |       | R/W-0 |     |     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-62. GPIO Port B Qualification Select 1 (GPBQSEL1) Register Field Descriptions

| Bits  | Field                         | Value | Description <sup>(1)</sup>                                                                                                                                                                                                  |
|-------|-------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-22 | Reserved                      |       | Reserved                                                                                                                                                                                                                    |
| 21-0  | GPIO 42-GPIO32 <sup>(2)</sup> |       | Select input qualification type for GPIO32 to GPIO42. The input qualification of each GPIO input is controlled by two bits as shown in .                                                                                    |
|       |                               | 00    | Synchronize to SYSCLKOUT only. Valid for both peripheral and GPIO pins.                                                                                                                                                     |
|       |                               | 01    | Qualification using 3 samples. Valid for pins configured as GPIO or a peripheral function.<br>The time between samples is specified in the GPACTRL register.                                                                |
|       |                               | 10    | Qualification using 6 samples. Valid for pins configured as GPIO or a peripheral function.<br>The time between samples is specified in the GPACTRL register.                                                                |
|       |                               | 11    | Asynchronous. (no synchronization or qualification). This option applies to pins configured as peripherals only. If the pin is configured as a GPIO input, then this option is the same as 0,0 or synchronize to SYSCLKOUT. |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> GPIO41 doesn't exist on this device. Bits corresponding to GPIO41 are reserved.

The GPADIR and GPBDIR registers control the direction of the pins when they are configured as a GPIO in the appropriate MUX register. The direction register has no effect on pins configured as peripheral functions.

|        | Figure 1-57. GPIO Port A Direction (GPADIR) Register |        |        |                         |        |        |        |  |  |  |  |
|--------|------------------------------------------------------|--------|--------|-------------------------|--------|--------|--------|--|--|--|--|
| 31     | 30                                                   | 29     | 28     | 27                      | 26     | 25     | 24     |  |  |  |  |
| GPIO31 | GPIO30                                               | GPIO29 | GPIO28 | GPIO27                  | GPIO26 | GPIO25 | GPIO24 |  |  |  |  |
| R/W-0  | R/W-0                                                | R/W-0  | R/W-0  | R/W-0                   | R/W-0  | R/W-0  | R/W-0  |  |  |  |  |
| 23     | 22                                                   | 21     | 20     | 19                      | 18     | 17     | 16     |  |  |  |  |
| GPIO23 | GPIO22                                               | GPIO21 | GPIO20 | GPIO19                  | GPIO18 | GPIO17 | GPIO16 |  |  |  |  |
| R/W-0  | R/W-0                                                | R/W-0  | R/W-0  | R/W-0                   | R/W-0  | R/W-0  | R/W-0  |  |  |  |  |
| 15     | 14                                                   | 13     | 12     | 11                      | 10     | 9      | 8      |  |  |  |  |
| GPIO15 | GPIO14                                               | GPIO13 | GPIO12 | GPIO11                  | GPIO10 | GPIO9  | GPIO8  |  |  |  |  |
| R/W-0  | R/W-0                                                | R/W-0  | R/W-0  | R/W-0                   | R/W-0  | R/W-0  | R/W-0  |  |  |  |  |
| 7      | 6                                                    | 5      | 4      | 3                       | 2      | 1      | 0      |  |  |  |  |
| GPIO7  | GPIO6                                                | GPIO5  | GPIO4  | GPIO3                   | GPIO2  | GPIO1  | GPIO0  |  |  |  |  |
| R/W-0  | R/W-0                                                | R/W-0  | R/W-0  | R/W-0 R/W-0 R/W-0 R/W-0 |        |        | R/W-0  |  |  |  |  |

# Figure 1-57. GPIO Port A Direction (GPADIR) Register

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 1-63. GPIO Port A Direction (GPADIR) Register Field Descriptions

| Bits | Field        | Value | Description <sup>(1)</sup>                                                                                                                                                                                   |
|------|--------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31-GPIO0 |       | Controls direction of GPIO Port A pins when the specified pin is configured as a GPIO in the appropriate GPAMUX1 or GPAMUX2 register.                                                                        |
|      |              | 0     | Configures the GPIO pin as an input. (default)                                                                                                                                                               |
|      |              | 1     | Configures the GPIO pin as an output                                                                                                                                                                         |
|      |              |       | The value currently in the GPADAT output latch is driven on the pin. To initialize the GPADAT latch prior to changing the pin from an input to an output, use the GPASET, GPACLEAR, and GPATOGGLE registers. |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

General-Purpose Input/Output (GPIO)

|        | Figure 1-58. GPIO Port B Direction (GPBDIR) Register |         |        |        |        |        |          |        |  |  |  |  |
|--------|------------------------------------------------------|---------|--------|--------|--------|--------|----------|--------|--|--|--|--|
| 31     |                                                      |         |        |        | 11     | 10     | 9        | 8      |  |  |  |  |
|        |                                                      | Reserve | ed     |        |        | GPIO42 | Reserved | GPIO40 |  |  |  |  |
|        |                                                      | R-0     |        |        |        | R/W-0  | R-0      | R/W-0  |  |  |  |  |
| 7      | 6                                                    | 5       | 4      | 3      | 2      |        | 1        | 0      |  |  |  |  |
| GPIO39 | GPIO38                                               | GPIO37  | GPIO36 | GPIO35 | GPIO34 | GP     | IO33     | GPIO32 |  |  |  |  |
| R-0    | R/W-0                                                | R/W-0   | R/W-0  | R/W-0  | R/W-0  | R/     | W-0      | R/W-0  |  |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 1-64. GPIO Port B Direction (GPBDIR) Register Field Descriptions

| Bit      | Field                            | Value        | Description <sup>(1)</sup>                                                                                                        |
|----------|----------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31-11    | Reserved                         |              | Reserved                                                                                                                          |
| 10-0     | GPIO42-<br>GPIO32 <sup>(2)</sup> |              | Controls direction of GPIO pin when GPIO mode is selected. Reading the register returns the current value of the register setting |
|          |                                  | 0            | Configures the GPIO pin as an input. (default)                                                                                    |
|          |                                  | 1            | Configures the GPIO pin as an output                                                                                              |
| 1) Think |                                  | a rata ata d | See Section 1.4.2 for more information                                                                                            |

<sup>1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> GPIO41 does not exist on this device. Bits corresponding to GPIO41 are reserved.

The pullup disable (GPxPUD) registers allow you to specify which pins should have an internal pullup resister enabled. The internal pullups on the pins that can be configured as ePWM outputs(GPIO0-GPIO11) are all disabled asynchronously when the external reset signal ( $\overline{XRS}$ ) is low. The internal pullups on all other pins are enabled on reset. When coming out of reset, the pullups remain in their default state until you enable or disable them selectively in software by writing to this register. The pullup configuration applies both to pins configured as I/O and those configured as peripheral functions.

#### Figure 1-59. GPIO Port A Pullup Disable (GPAPUD) Registers

|        |        | 0      |        | •      | · /    | 0      |        |
|--------|--------|--------|--------|--------|--------|--------|--------|
| 31     | 30     | 29     | 28     | 27     | 26     | 25     | 24     |
| GPIO31 | GPIO30 | GPIO29 | GPIO28 | GPIO27 | GPIO26 | GPIO25 | GPIO24 |
| R/W-0  |
| 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
| GPIO23 | GPIO22 | GPIO21 | GPIO20 | GPIO19 | GPIO18 | GPIO17 | GPIO16 |
| R/W-0  |
| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| GPIO15 | GPIO14 | GPIO13 | GPIO12 | GPIO11 | GPIO10 | GPIO9  | GPIO8  |
| R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-1  | R/W-1  | R/W-1  | R/W-1  |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| GPIO7  | GPIO6  | GPIO5  | GPIO4  | GPIO3  | GPIO2  | GPIO1  | GPIO0  |
| R/W-1  |
|        |        |        |        |        |        |        |        |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 1-65. GPIO Port A Internal Pullup Disable (GPAPUD) Register Field Descriptions

| Bits | Field        | Value | Description <sup>(1)</sup>                                                                                                     |
|------|--------------|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31-GPIO0 |       | Configure the internal pullup resister on the selected GPIO Port A pin. Each GPIO pin corresponds to one bit in this register. |
|      |              | 0     | Enable the internal pullup on the specified pin. (default for GPIO12-GPIO31)                                                   |
|      |              | 1     | Disable the internal pullup on the specified pin. (default for GPIO0-GPIO11)                                                   |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.



#### General-Purpose Input/Output (GPIO)

#### www.ti.com

#### Figure 1-60. GPIO Port B Pullup Disable (GPBPUD) Registers

| 31     |        |          |        |        |        |          | 16     |
|--------|--------|----------|--------|--------|--------|----------|--------|
|        |        |          | Rese   | erved  |        |          |        |
|        |        |          | R      | -0     |        |          |        |
| 15     |        |          |        | 11     | 10     | 9        | 8      |
|        |        | Reserved |        |        | GPIO42 | Reserved | GPIO40 |
|        |        | R-0      |        |        | R/W-0  | R-0      | R/W-0  |
| 7      | 6      | 5        | 4      | 3      | 2      | 1        | 0      |
| GPIO39 | GPIO38 | GPIO37   | GPIO36 | GPIO35 | GPIO34 | GPIO33   | GPIO32 |
| R/W-0  | R/W-0  | R/W-0    | R/W-0  | R/W-0  | R/W-0  | R/W-0    | R/W-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-66. GPIO Port B Internal Pullup Disable (GPBPUD) Register Field Descriptions

| Bits   | Field                            | Value | Description <sup>(1)</sup>                                                                                                     |
|--------|----------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 31- 11 | Reserved                         |       |                                                                                                                                |
| 10-0   | GPIO42-<br>GPIO32 <sup>(2)</sup> |       | Configure the internal pullup resister on the selected GPIO Port B pin. Each GPIO pin corresponds to one bit in this register. |
|        |                                  | 0     | Enable the internal pullup on the specified pin. (default)                                                                     |
|        |                                  | 1     | Disable the internal pullup on the specified pin.                                                                              |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.

<sup>(2)</sup> GPIO41 does not exist on this device. Bits corresponding to GPIO41 are reserved.

The GPIO data registers indicate the current status of the GPIO pin, irrespective of which mode the pin is in. Writing to this register will set the respective GPIO pin high or low if the pin is enabled as a GPIO output, otherwise the value written is latched but ignored. The state of the output register latch will remain in its current state until the next write operation. A reset will clear all bits and latched values to zero. The value read from the GPxDAT registers reflect the state of the pin (after qualification), not the state of the output latch of the GPxDAT register.

Typically the DAT registers are used for reading the current state of the pins. To easily modify the output level of the pin refer to the SET, CLEAR and TOGGLE registers.

|        |        | -      |        | •      |        |        |        |
|--------|--------|--------|--------|--------|--------|--------|--------|
| 31     | 30     | 29     | 28     | 27     | 26     | 25     | 24     |
| GPIO31 | GPIO30 | GPIO29 | GPIO28 | GPIO27 | GPIO26 | GPIO25 | GPIO24 |
| R/W-x  |
| 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
| GPIO23 | GPIO22 | GPIO21 | GPIO20 | GPIO19 | GPIO18 | GPIO17 | GPIO16 |
| R/W-x  |
| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| GPIO15 | GPIO14 | GPIO13 | GPIO12 | GPIO11 | GPIO10 | GPIO9  | GPIO8  |
| R/W-x  |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| GPIO7  | GPIO6  | GPIO5  | GPIO4  | GPIO3  | GPIO2  | GPIO1  | GPIO0  |
| R/W-x  |
|        |        |        |        |        |        |        |        |

#### Figure 1-61. GPIO Port A Data (GPADAT) Register

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset<sup>(1)</sup>

 $^{(1)}$  x = The state of the GPADAT register is unknown after reset. It depends on the level of the pin after reset.

| Bits | Field        | Value | Description                                                                                                                                                                                       |
|------|--------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31-GPIO0 |       | Each bit corresponds to one GPIO port A pin (GPIO0-GPIO31) as shown in Figure 1-61.                                                                                                               |
|      |              | 0     | Reading a 0 indicates that the state of the pin is currently low, irrespective of the mode the pin is configured for.                                                                             |
|      |              |       | Writing a 0 will force an output of 0 if the pin is configured as a GPIO output in the appropriate GPAMUX1/2 and GPADIR registers; otherwise, the value is latched but not used to drive the pin. |
|      |              | 1     | Reading a 1 indicates that the state of the pin is currently high irrespective of the mode the pin is configured for.                                                                             |
|      |              |       | Writing a 1will force an output of 1if the pin is configured as a GPIO output in the appropriate GPAMUX1/2 and GPADIR registers; otherwise, the value is latched but not used to drive the pin.   |

## Table 1-67. GPIO Port A Data (GPADAT) Register Field Descriptions

## Figure 1-62. GPIO Port B Data (GPBDAT) Register

| 31     |        |          |        |        |        |          | 16     |
|--------|--------|----------|--------|--------|--------|----------|--------|
|        |        |          | Rese   | erved  |        |          |        |
|        |        |          | R      | -0     |        |          |        |
| 15     |        |          |        | 11     | 10     | 9        | 8      |
|        |        | Reserved |        |        | GPIO42 | Reserved | GPIO40 |
|        |        | R-0      |        |        | R/W-x  | R-0      | R/W-x  |
| 7      | 6      | 5        | 4      | 3      | 2      | 1        | 0      |
| GPIO39 | GPIO38 | GPIO37   | GPIO36 | GPIO35 | GPIO34 | GPIO33   | GPIO32 |
| R/W-x  | R/W-x  | R/W-x    | R/W-x  | R/W-x  | R/W-x  | R/W-x    | R/W-x  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset<sup>(1)</sup>

(1) x = The state of the GPADAT register is unknown after reset. It depends on the level of the pin after reset.

## Table 1-68. GPIO Port B Data (GPBDAT) Register Field Descriptions

| Bit    | Field                        | Value | Description                                                                                                                                                                                     |
|--------|------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31- 11 | Reserved                     |       | Reserved                                                                                                                                                                                        |
| 10-0   | GPIO42-GPIO32 <sup>(1)</sup> |       | Each bit corresponds to one GPIO port B pin (GPIO32-GPIO 44) as shown in Figure 1-62.                                                                                                           |
|        |                              | 0     | Reading a 0 indicates that the state of the pin is currently low, irrespective of the mode the pin is configured for.                                                                           |
|        |                              |       | Writing a 0 will force an output of 0 if the pin is configured as a GPIO output in the appropriate GPBMUX1 and GPBDIR registers; otherwise, the value is latched but not used to drive the pin. |
|        |                              | 1     | Reading a 1 indicates that the state of the pin is currently high irrespective of the mode the pin is configured for.                                                                           |
|        |                              |       | Writing a 1 will force an output of 1 if the pin is configured as a GPIO output in the GPBMUX1 and GPBDIR registers; otherwise, the value is latched but not used to drive the pin.             |

<sup>(1)</sup> GPIO41 does not exist on this device. Bits corresponding to GPIO41 are reserved.



#### General-Purpose Input/Output (GPIO)

| Figu   | re 1-63. GPIO | Port A Set, C | lear and Tog | gle (GPASET, | GPACLEAR, | GPATOGGLE | E) Registers |
|--------|---------------|---------------|--------------|--------------|-----------|-----------|--------------|
| 31     | 30            | 29            | 28           | 27           | 26        | 25        | 24           |
| GPIO31 | GPIO30        | GPIO29        | GPIO28       | GPIO27       | GPIO26    | GPIO25    | GPIO24       |
| R/W-0  | R/W-0         | R/W-0         | R/W-0        | R/W-0        | R/W-0     | R/W-0     | R/W-0        |
| 23     | 22            | 21            | 20           | 19           | 18        | 17        | 16           |
| GPIO23 | GPIO22        | GPIO21        | GPIO20       | GPIO19       | GPIO18    | GPIO17    | GPIO16       |
| R/W-0  | R/W-0         | R/W-0         | R/W-0        | R/W-0        | R/W-0     | R/W-0     | R/W-0        |
| 15     | 14            | 13            | 12           | 11           | 10        | 9         | 8            |
| GPIO15 | GPIO14        | GPIO13        | GPIO12       | GPIO11       | GPIO10    | GPIO9     | GPIO8        |
| R/W-0  | R/W-0         | R/W-0         | R/W-0        | R/W-0        | R/W-0     | R/W-0     | R/W-0        |
| 7      | 6             | 5             | 4            | 3            | 2         | 1         | 0            |
| GPIO7  | GPIO6         | GPIO5         | GPIO4        | GPIO3        | GPIO2     | GPIO1     | GPIO0        |
| R/W-0  | R/W-0         | R/W-0         | R/W-0        | R/W-0        | R/W-0     | R/W-0     | R/W-0        |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-69. GPIO Port A Set (GPASET) Register Field Descriptions

| Bits | Field        | Value | Description                                                                                                                                                                                                                             |
|------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31-GPIO0 |       | Each GPIO port A pin (GPIO0-GPIO31) corresponds to one bit in this register as shown in Figure 1-63.                                                                                                                                    |
|      |              | 0     | Writes of 0 are ignored. This register always reads back a 0.                                                                                                                                                                           |
|      |              | 1     | Writing a 1 forces the respective output data latch to high. If the pin is configured as a GPIO output then it will be driven high. If the pin is not configured as a GPIO output then the latch is set high but the pin is not driven. |

#### Table 1-70. GPIO Port A Clear (GPACLEAR) Register Field Descriptions

| Bits | Field          | Value | Description                                                                                                                                                                                                                          |
|------|----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31 - GPIO0 |       | Each GPIO port A pin (GPIO0-GPIO31) corresponds to one bit in this register as shown in Figure 1-63.                                                                                                                                 |
|      |                | 0     | Writes of 0 are ignored. This register always reads back a 0.                                                                                                                                                                        |
|      |                | 1     | Writing a 1 forces the respective output data latch to low. If the pin is configured as a GPIO output then it will be driven low. If the pin is not configured as a GPIO output then the latch is cleared but the pin is not driven. |

## Table 1-71. GPIO Port A Toggle (GPATOGGLE) Register Field Descriptions

| Bits | Field        | Value | Description                                                                                                                                                                                                                                                                                               |
|------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31-GPIO0 |       | Each GPIO port A pin (GPIO0-GPIO31) corresponds to one bit in this register as shown in Figure 1-<br>63.                                                                                                                                                                                                  |
|      |              | 0     | Writes of 0 are ignored. This register always reads back a 0.                                                                                                                                                                                                                                             |
|      |              | 1     | Writing a 1 forces the respective output data latch to toggle from its current state. If the pin is configured as a GPIO output then it will be driven in the opposite direction of its current state. If the pin is not configured as a GPIO output then the latch is toggled but the pin is not driven. |

## Figure 1-64. GPIO Port B Set, Clear and Toggle (GPBSET, GPBCLEAR, GPBTOGGLE) Registers

| 31           |                 |                    |                  |        |        |          | 16     |
|--------------|-----------------|--------------------|------------------|--------|--------|----------|--------|
|              |                 |                    | Rese             | erved  |        |          |        |
|              |                 |                    | R                | -0     |        |          |        |
| 15           |                 |                    |                  | 11     | 10     | 9        | 8      |
|              |                 | Reserved           |                  |        | GPIO42 | Reserved | GPIO40 |
|              |                 | R-0                |                  |        | R/W-x  | R-0      | R/W-x  |
| 7            | 6               | 5                  | 4                | 3      | 2      | 1        | 0      |
| GPIO39       | GPIO38          | GPIO37             | GPIO36           | GPIO35 | GPIO34 | GPIO33   | GPIO32 |
| R/W-x        | R/W-x           | R/W-x              | R/W-x            | R/W-x  | R/W-x  | R/W-x    | R/W-x  |
| EGEND: R/W = | Read/Write; R = | Read only; -n = va | alue after reset |        |        |          |        |

112 System Control and Interrupts



#### Table 1-72. GPIO Port B Set (GPBSET) Register Field Descriptions

| Bits   | Field                         | Value | Description                                                                                                                                                                                                                        |
|--------|-------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31- 11 | Reserved                      |       | Reserved                                                                                                                                                                                                                           |
| 10 -0  | GPIO42 -GPIO32 <sup>(1)</sup> |       | Each GPIO port B pin (GPIO32-GPIO42) corresponds to one bit in this register as shown in Figure 1-64.                                                                                                                              |
|        |                               | 0     | Writes of 0 are ignored. This register always reads back a 0.                                                                                                                                                                      |
|        |                               | 1     | Writing a 1 forces the respective output data latch to high. If the pin is configured as a GPIO output then it will be driven high. If the pin is not configured as a GPIO output then the latch is set but the pin is not driven. |

<sup>(1)</sup> GPIO41 does not exist on this device. Bits corresponding to GPIO41 are reserved.

## Table 1-73. GPIO Port B Clear (GPBCLEAR) Register Field Descriptions

| Bits   | Field                        | Value | Description                                                                                                                                                                                                                          |
|--------|------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31- 11 | Reserved                     |       |                                                                                                                                                                                                                                      |
| 10 -0  | GPIO42-GPIO32 <sup>(1)</sup> |       | Each GPIO port B pin (GPIO32-GPIO42) corresponds to one bit in this register as shown in Figure 1-64.                                                                                                                                |
|        |                              | 0     | Writes of 0 are ignored. This register always reads back a 0.                                                                                                                                                                        |
|        |                              | 1     | Writing a 1 forces the respective output data latch to low. If the pin is configured as a GPIO output then it will be driven low. If the pin is not configured as a GPIO output then the latch is cleared but the pin is not driven. |

<sup>(1)</sup> GPIO41 does not exist on this device. Bits corresponding to GPIO41 are reserved.

## Table 1-74. GPIO Port B Toggle (GPBTOGGLE) Register Field Descriptions

| Bits   | Field                        | Value | Description                                                                                                                                                                                                                                                                                               |
|--------|------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31- 11 | Reserved                     |       |                                                                                                                                                                                                                                                                                                           |
| 10 -0  | GPIO42-GPIO32 <sup>(1)</sup> |       | Each GPIO port B pin (GPIO32-GPIO42) corresponds to one bit in this register as shown in Figure 1-64.                                                                                                                                                                                                     |
|        |                              | 0     | Writes of 0 are ignored. This register always reads back a 0.                                                                                                                                                                                                                                             |
| L      |                              | 1     | Writing a 1 forces the respective output data latch to toggle from its current state. If the pin is configured as a GPIO output then it will be driven in the opposite direction of its current state. If the pin is not configured as a GPIO output then the latch is cleared but the pin is not driven. |

<sup>(1)</sup> GPIO41 does not exist on this device. Bits corresponding to GPIO41 are reserved.

## Figure 1-65. GPIO XINTn Interrupt Select (GPIOXINTnSEL) Registers

| 15 5     | 4 | 0            |
|----------|---|--------------|
| Reserved |   | GPIOXINTnSEL |
|          |   | R/W-0        |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 1-75. GPIO XINTn Interrupt Select (GPIOXINTnSEL)<sup>(1)</sup> Register Field Descriptions

| Bits | Field        | Value | Description <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                              |
|------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-5 | Reserved     |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 4-0  | GPIOXINTnSEL |       | Select the port A GPIO signal (GPIO0 - GPIO31) that will be used as the XINT1, XINT2, or XINT3 interrupt source. In addition, you can configure the interrupt in the XINT1CR, XINT2CR, or XINT3CR registers described in Section 1.5.6.<br>To use XINT2 as ADC start of conversion, enable it in the desired ADCSOCxCTL register.<br>The ADCSOC signal is always rising edge sensitive. |
|      |              | 00000 | Select the GPIO0 pin as the XINTn interrupt source (default)                                                                                                                                                                                                                                                                                                                            |
|      |              | 00001 | Select the GPIO1 pin as the XINTn interrupt source                                                                                                                                                                                                                                                                                                                                      |
|      |              |       |                                                                                                                                                                                                                                                                                                                                                                                         |
|      |              | 11110 | Select the GPIO30 pin as the XINTn interrupt source                                                                                                                                                                                                                                                                                                                                     |
|      |              | 11111 | Select the GPIO31 pin as the XINTn interrupt source                                                                                                                                                                                                                                                                                                                                     |

<sup>(1)</sup> n = 1 or 2

<sup>(2)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.



#### General-Purpose Input/Output (GPIO)

www.ti.com

| n | Interrupt | Interrupt Select Register | Configuration Register |
|---|-----------|---------------------------|------------------------|
| 1 | XINT1     | GPIOXINT1SEL              | XINT1CR                |
| 2 | XINT2     | GPIOXINT2SEL              | XINT2CR                |
| 3 | XINT3     | GPIOXINT3SEL              | XINT3CR                |

## Figure 1-66. GPIO Low Power Mode Wakeup Select (GPIOLPMSEL) Register

| 31         | 30         | 29         | 28         | 27         | 26         | 25                  | 24         |
|------------|------------|------------|------------|------------|------------|---------------------|------------|
| GPIO31     | GPIO30     | GPIO29     | GPIO28     | GPIO27     | GPIO26     | GPIO25              | GPIO24     |
| R/W-0               | R/W-0      |
| 23         | 22         | 21         | 20         | 19         | 18         | 17                  | 16         |
| GPIO23     | GPIO22     | GPIO21     | GPIO20     | GPIO19     | GPIO18     | GPIO17              | GPIO16     |
| R/W-0               | R/W-0      |
| 15         | 14         | 13         | 12         | 11         | 10         | 9                   | 8          |
| GPIO15     | GPIO14     | GPIO13     | GPIO12     | GPIO11     | GPIO10     | GPIO9               | GPIO8      |
| R/W-0      |            |            |            |            |            |                     |            |
| N/W-0      | R/W-0      | R/W-0      | R/W-0      | R/W-0      | R/W-0      | R/W-0               | R/W-0      |
| 7          | R/W-0<br>6 | R/W-0<br>5 | R/W-0<br>4 | R/W-0<br>3 | R/W-0<br>2 | R/W-0<br>1          | R/W-0<br>0 |
| 7<br>GPIO7 |            |            |            |            |            | R/W-0<br>1<br>GPIO1 |            |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

## Table 1-77. GPIO Low Power Mode Wakeup Select (GPIOLPMSEL) Register Field Descriptions

| Bits | Field          | Value | Description <sup>(1)</sup>                                                                                                                    |
|------|----------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31 - GPIO0 |       | Low Power Mode Wakeup Selection. Each bit in this register corresponds to one GPIO port A pin (GPIO0 - GPIO31) as shown in Figure 8-14.       |
|      |                | 0     | If the bit is cleared, the signal on the corresponding pin will have no effect on the HALT and STANDBY low power modes.                       |
|      |                | 1     | If the respective bit is set to 1, the signal on the corresponding pin is able to wake the device from both HALT and STANDBY low power modes. |

<sup>(1)</sup> This register is EALLOW protected. See Section 1.4.2 for more information.



## 1.4 Peripheral Frames

This chapter describes the peripheral frames. It also describes the device emulation registers.

## 1.4.1 Peripheral Frame Registers

These devices contain four peripheral register spaces. The spaces are categorized as follows:

- Peripheral Frame 0: These are peripherals that are mapped directly to the CPU memory bus. See Table 1-78.
- Peripheral Frame 1: These are peripherals that are mapped to the 32-bit peripheral bus. See Table 1-79.
- Peripheral Frame 2: These are peripherals that are mapped to the 16-bit peripheral bus. See Table 1-80.

| Name                                                  | Address Range    | Size (x16) | Access Type <sup>(2)</sup> |
|-------------------------------------------------------|------------------|------------|----------------------------|
| Device Emulation Registers                            | 0x0880 - 0x0984  | 261        | EALLOW protected           |
| System Power Control Registers                        | 0x0985 - 0x0987  | 3          | EALLOW protected           |
| FLASH Registers <sup>(3)</sup>                        | 0x0A80 - 0x0ADF  | 96         | EALLOW protected           |
| Dual Code Security Module<br>Registers                | 0x0B80 - 0x0BFF  | 128        | EALLOW protected           |
| ADC registers (dual-mapped) (0 wait, read only, CPU ) | 0x0B00 - 0x0B1F  | 32         | Not EALLOW protected       |
| CPU–TIMER0/1/2 Registers                              | 0x 0C00 - 0x0C3F | 64         | Not EALLOW protected       |
| PIE Registers                                         | 0x0CE0 - 0x0CFF  | 32         | Not EALLOW protected       |
| PIE Vector Table                                      | 0x0D00 - 0x0DFF  | 256        | EALLOW protected           |
| CLA Registers                                         | 0x1400 - 0x147F  | 128        | Yes                        |
| CLA to CPU Message RAM (CPU writes ignored)           | 0x1480 - 0x14FF  | 128        | N/A                        |
| CPU to CLA Message RAM (CLA writes ignored)           | 0x1500 - 0x157F  | 128        | N/A                        |

### Table 1-78. Peripheral Frame 0 Registers<sup>(1)</sup>

<sup>(1)</sup> Registers in Frame 0 support 16-bit and 32-bit accesses.

<sup>(2)</sup> If registers are EALLOW protected, then writes cannot be performed until the EALLOW instruction is executed. The EDIS instruction disables writes to prevent stray code or pointers from corrupting register contents.

<sup>(3)</sup> The Flash registers are also protected by the dual code security module (DCSM). See Section 1.7 for more information.

Peripheral Frames

## TEXAS INSTRUMENTS

#### www.ti.com

| Table 1-79. Peripheral Frame 1 Registers <sup>(1)</sup> |                 |            |                            |  |  |
|---------------------------------------------------------|-----------------|------------|----------------------------|--|--|
| Name                                                    | Address Range   | Size (x16) | Access Type <sup>(2)</sup> |  |  |
| eCANA Registers                                         | 0x6000 - 0x60FF | 256        | _ (3)                      |  |  |
| eCANA Mailbox RAM                                       | 0x6100 - 0x61FF | 256        | Not EALLOW protected       |  |  |
| Analog PFE Registers                                    | 0x6400 - 0x64FF | 256        | _(3)                       |  |  |
| ePWM1 Registers                                         | 0x6800 - 0x683F | 64         | (3)                        |  |  |
| ePWM2 Registers                                         | 0x6840 - 0x687F | 64         | (3)                        |  |  |
| ePWM3 Registers                                         | 0x6880 - 0x68BF | 64         | (3)                        |  |  |
| ePWM4 Registers                                         | 0x68C0 - 0x68FF | 64         | (3)                        |  |  |
| ePWM5 Registers                                         | 0x6900 - 0x693F | 64         | (3)                        |  |  |
| ePWM6 Registers                                         | 0x6940 - 0x697F | 64         | (3)                        |  |  |
| ePWM7 Registers                                         | 0x6980 - 0x69BF | 64         | (3)                        |  |  |
| eCAP1 Registers                                         | 0x6A00 - 0x6A1F | 32         | Not EALLOW-protected       |  |  |
| eQEP1 Registers                                         | 0x6B00 - 0x6B3F | 64         | Not EALLOW-protected       |  |  |
| GPIO Control Registers                                  | 0x6F80 - 0x6FBF | 128        | EALLOW-protected           |  |  |
| GPIO Data Registers                                     | 0x6FC0 - 0x6FDF | 32         | Not EALLOW-protected       |  |  |
| GPIO Interrupt and LPM Select<br>Registers              | 0x6FE0 - 0x6FFF | 32         | EALLOW-protected           |  |  |

<sup>(1)</sup> Back-to-back write operations to Peripheral Frame 1 registers will incur a 1-cycle stall (1 cycle delay).

<sup>(2)</sup> Peripheral Frame 1 allows 16-bit and 32-bit accesses. All 32-bit accesses are aligned to even address boundaries.

<sup>(3)</sup> Some Registers/Bits are EALLOW protected. See the module reference guide for more information.

| Name                             | Address Range   | Size (x16) | Access Type <sup>(1)</sup> |
|----------------------------------|-----------------|------------|----------------------------|
| System Control Registers         | 0x7010 - 0x702F | 32         | EALLOW-protected           |
| SPI-A Registers                  | 0x7040 - 0x704F | 16         | Not EALLOW protected       |
| SCI-A Registers                  | 0x7050 - 0x705F | 16         | Not EALLOW protected       |
| NMI Watchdog Interrupt Registers | 0x7060 - 0x706F | 16         |                            |
| External Interrupt Registers     | 0x7070 - 0x707F | 16         | Not EALLOW protected       |
| ADC Registers                    | 0x7100 - 0x711F | 32         | Not EALLOW protected       |
| SCI-B Registers                  | 0x7750 - 0x775F | 16         | Not EALLOW protected       |
| SCI-C Registers                  | 0x7770 - 0x777F | 16         | Not EALLOW protected       |
| I <sup>2</sup> C Registers       | 0x7900 - 0x793F | 64         | Not EALLOW protected       |

## Table 1-80. Peripheral Frame 2 Registers

<sup>(1)</sup> Peripheral Frame 2 only allows 16-bit accesses. All 32-bit accesses are ignored (invalid data can be returned or written).

Peripheral Frames

## 1.4.2 EALLOW-Protected Registers

Several control registers are protected from spurious CPU writes by the EALLOW protection mechanism. The EALLOW bit in status register 1 (ST1) indicates if the state of protection as shown in Table 1-81.

|            |            |           | 0                      |            |
|------------|------------|-----------|------------------------|------------|
| EALLOW Bit | CPU Writes | CPU Reads | JTAG Writes            | JTAG Reads |
| 0          | Ignored    | Allowed   | Allowed <sup>(1)</sup> | Allowed    |
| 1          | Allowed    | Allowed   | Allowed                | Allowed    |

Table 1-81. Access to EALLOW-Protected Registers

<sup>(1)</sup> The EALLOW bit is overridden via the JTAG port, allowing full access of protected registers during debug from the Code Composer Studio interface.

At reset the EALLOW bit is cleared enabling EALLOW protection. While protected, all writes to protected registers by the CPU are ignored and only CPU reads, JTAG reads, and JTAG writes are allowed. If this bit is set, by executing the EALLOW instruction, then the CPU is allowed to write freely to protected registers. After modifying registers, they can once again be protected by executing the EDI instruction to clear the EALLOW bit.

The following registers are EALLOW-protected:

- Device Emulation Registers
- Flash Registers
- DCSM Registers
- PIE Vector Table
- System Control Registers
- GPIO MUX Registers

#### Table 1-82. EALLOW-Protected Device Emulation Registers

| Name      | Address          | Size<br>(x16) | Description                   |
|-----------|------------------|---------------|-------------------------------|
| DEVICECNF | 0x0880<br>0x0881 | 2             | Device Configuration Register |

#### Table 1-83. EALLOW-Protected Flash/OTP Configuration Registers

| Name        | Address | Size<br>(x16) | Description                                 |
|-------------|---------|---------------|---------------------------------------------|
| FOPT        | 0x0A80  | 1             | Flash Option Register                       |
| FPWR        | 0x0A82  | 1             | Flash Power Modes Register                  |
| FSTATUS     | 0x0A83  | 1             | Status Register                             |
| FSTDBYWAIT  | 0x0A84  | 1             | Flash Sleep To Standby Wait State Register  |
| FACTIVEWAIT | 0x0A85  | 1             | Flash Standby To Active Wait State Register |
| FBANKWAIT   | 0x0A86  | 1             | Flash Read Access Wait State Register       |
| FOTPWAIT    | 0x0A87  | 1             | OTP Read Access Wait State Register         |



Peripheral Frames

www.ti.com

## Table 1-84. EALLOW-Protected Code Security Module (DCSM) Registers (Zone 1)

| Offset | Acronym         | Register Name                                |
|--------|-----------------|----------------------------------------------|
| Oh     | Z1_LINKPOINTER  | Zone 1 Link Pointer                          |
| 8h     | Z1_BOOTMODE     | Boot Mode                                    |
| 20h    | Z1_CSMKEY0      | Zone 1 CSM Key 0                             |
| 24h    | Z1_CSMKEY1      | Zone 1 CSM Key 1                             |
| 28h    | Z1_CSMKEY2      | Zone 1 CSM Key 2                             |
| 2Ch    | Z1_CSMKEY3      | Zone 1 CSM Key 3                             |
| 32h    | Z1_CR           | Zone 1 CSM Control Register                  |
| 34h    | Z1_GRABSECTR    | Zone 1 Grab Flash Sectors Register           |
| 38h    | Z1_GRABRAMR     | Zone 1 Grab RAM Blocks Register              |
| 3Ch    | Z1_EXEONLYSECTR | Zone 1 Flash Execute_Only Sector<br>Register |
| 40h    | Z1_EXEONLYRAMR  | Zone 1 RAM Execute_Only Block Register       |

## Table 1-85. EALLOW-Protected Code Security Module (DCSM) Registers (Zone 2)

| Offset | Acronym         | Register Name                                |
|--------|-----------------|----------------------------------------------|
| 0h     | Z2_LINKPOINTER  | Zone 2 Link Pointer                          |
| 8h     | Z2_BOOTMODE     | Boot Mode                                    |
| 20h    | Z2_CSMKEY0      | Zone 2 CSM Key 0                             |
| 24h    | Z2_CSMKEY1      | Zone 2 CSM Key 1                             |
| 28h    | Z2_CSMKEY2      | Zone 2 CSM Key 2                             |
| 2Ch    | Z2_CSMKEY3      | Zone 2 CSM Key 3                             |
| 32h    | Z2_CR           | Zone 2 CSM Control Register                  |
| 34h    | Z2_GRABSECTR    | Zone 2 Grab Flash Sectors Register           |
| 38h    | Z2_GRABRAMR     | Zone 2 Grab RAM Blocks Register              |
| 3Ch    | Z2_EXEONLYSECTR | Zone 2 Flash Execute_Only Sector<br>Register |
| 40h    | Z2_EXEONLYRAMR  | Zone 2 RAM Execute_Only Block Register       |
|        | FLSEM           | Flash Wrapper Semaphore Register             |
|        | SECTSTAT        | Sectors Status Register                      |
|        | RAMSTAT         | RAM Status Register                          |

### Table 1-86. EALLOW-Protected PLL, Clocking, Watchdog, and Low-Power Mode Registers

| Name        | Address     | Size<br>(x16) | Description                                    |
|-------------|-------------|---------------|------------------------------------------------|
| XCLK        | 0x0000-7010 | 1             | XCLKOUT/XCLKIN Control                         |
| PLLSTS      | 0x0000-7011 | 1             | PLL Status Register                            |
| CLKCTL      | 0x0000-7012 | 1             | Clock Control Register                         |
| PLLLOCKPRD  | 0x0000-7013 | 1             | PLL Lock Period Register                       |
| INTOSC1TRIM | 0x0000-7014 | 1             | Internal Oscillator 1 Trim Register            |
| INTOSC2TRIM | 0x0000-7016 | 1             | Internal Oscillator 2 Trim Register            |
| LOSPCP      | 0x0000-701B | 1             | Low-Speed Peripheral Clock Pre-Scaler Register |
| PCLKCR0     | 0x0000-701C | 1             | Peripheral Clock Control Register 0            |
| PCLKCR1     | 0x0000-701D | 1             | Peripheral Clock Control Register 1            |
| LPMCR0      | 0x0000-701E | 1             | Low Power Mode Control Register 0              |
| PCLKCR3     | 0x0000-7020 | 1             | Peripheral Clock Control Register 3            |
| PLLCR       | 0x0000-7021 | 1             | PLL Control Register                           |
| SCSR        | 0x0000-7022 | 1             | System Control & Status Register               |



# Table 1-86. EALLOW-Protected PLL, Clocking, Watchdog, and Low-Power Mode Registers (continued)

| Name    | Address     | Size<br>(x16) | Description                         |  |
|---------|-------------|---------------|-------------------------------------|--|
| WDCNTR  | 0x0000-7023 | 1             | Watchdog Counter Register           |  |
| PCLKCR4 | 0x0000-7024 | 1             | Peripheral Clock Control Register 4 |  |
| WDKEY   | 0x0000-7025 | 1             | Watchdog Reset Key Register         |  |
| WDCR    | 0x0000-7029 | 1             | Watchdog Control Register           |  |

TEXAS INSTRUMENTS

www.ti.com

Peripheral Frames

#### Table 1-87. EALLOW-Protected GPIO Registers Name (1) Address Size (x16) **Register Description** GPACTRL 2 0x6F80 **GPIO A Control Register** 2 GPAQSEL1 0x6F82 **GPIO A Qualifier Select 1 Register** 2 GPAQSEL2 0x6F84 **GPIO A Qualifier Select 2 Register** 2 GPAMUX1 0x6F86 GPIO A MUX 1 Register 2 GPAMUX2 0x6F88 GPIO A MUX 2 Register GPADIR 2 **GPIO A Direction Register** 0x6F8A 2 GPAPUD 0x6F8C GPIO A Pull Up Disable Register GPBCTRL 0x6F90 2 **GPIO B Control Register** 2 GPBQSEL1 0x6F92 GPIO B Qualifier Select 1 Register 2 GPBMUX1 0x6F96 GPIO B MUX 1 Register 2 GPBMUX2 GPIO B MUX 2 Register 0x6F98 2 GPBDIR 0x6F9A **GPIO B Direction Register** GPBPUD 0x6F9C 2 GPIO B Pull Up Disable Register **GPIOXINT1SEL** 0x6FE0 1 XINT1 Source Select Register (GPIO0-GPIO31) **GPIOXINT2SEL** 1 0x6FE1 XINT2 Source Select Register (GPIO0-GPIO31) **GPIOXINT3SEL** 0x6FE2 1 XINT3 Source Select Register (GPIO0 - GPIO31) GPIOLPMSEL 1 LPM wakeup Source Select Register (GPIO0-GPIO31) 0x6FE8

<sup>(1)</sup> The registers in this table are EALLOW protected. See Section 1.4.2 for more information.

Table 1-89 shows addresses for the following ePWM EALLOW-protected registers:

- Trip Zone Select Register (TZSEL)
- Trip Zone Control Register (TZCTL)
- Trip Zone Enable Interrupt Register (TZEINT)
- Trip Zone Clear Register (TZCLR)
- Trip Zone Force Register (TZFRC)

Texas Instruments

#### www.ti.com

Table 1-88. EALLOW-Protected PIE Vector Table

|          |         | Size  |                                                                 |
|----------|---------|-------|-----------------------------------------------------------------|
| Name     | Address | (x16) | Description                                                     |
| Not used | 0x0D00  | 2     | Reserved                                                        |
|          | 0x0D02  |       |                                                                 |
|          | 0x0D04  |       |                                                                 |
|          | 0x0D06  |       |                                                                 |
|          | 0x0D08  |       |                                                                 |
|          | 0x0D0A  |       |                                                                 |
|          | 0x0D0C  |       |                                                                 |
|          | 0x0D0E  |       |                                                                 |
|          | 0x0D10  |       |                                                                 |
|          | 0x0D12  |       |                                                                 |
|          | 0x0D14  |       |                                                                 |
|          | 0x0D16  |       |                                                                 |
|          | 0x0D18  |       |                                                                 |
| INT13    | 0x0D1A  | 2     | External Interrupt 13 (XINT13) or<br>CPU-Timer 1 (for RTOS use) |
| INT14    | 0x0D1C  | 2     | CPU-Timer 2 (for RTOS use)                                      |
| DATALOG  | 0x0D1E  | 2     | CPU Data Logging Interrupt                                      |
| RTOSINT  | 0x0D20  | 2     | CPU Real-Time OS Interrupt                                      |
| EMUINT   | 0x0D22  | 2     | CPU Emulation Interrupt                                         |
| NMI      | 0x0D24  | 2     | External Non-Maskable Interrupt                                 |
| ILLEGAL  | 0x0D26  | 2     | Illegal Operation                                               |
| USER1    | 0x0D28  | 2     | User-Defined Trap                                               |
|          |         |       |                                                                 |
| USER12   | 0x0D3E  | 2     | User-Defined Trap                                               |
| INT1.1   | 0x0D40  | 2     | Group 1 Interrupt Vectors                                       |
| INT1.8   | 0x0D4E  | 2     |                                                                 |
|          |         | •     | Group 2 Interrupt Vectors                                       |
|          |         | •     | to Group 11 Interrupt Vectors                                   |
| INT12.1  | 0x0DF0  | 2     | Group 12 Interrupt Vectors                                      |
| INT12.8  | 0x0DFE  | 2     |                                                                 |

|       | TZSEL  | TZCTL  | TZEINT | TZCLR  | TZFRC  | Size x16 |
|-------|--------|--------|--------|--------|--------|----------|
| ePWM1 | 0x6812 | 0x6814 | 0x6815 | 0x6817 | 0x6818 | 1        |
| ePWM2 | 0x6852 | 0x6854 | 0x6855 | 0x6857 | 0x6858 | 1        |
| ePWM3 | 0x6892 | 0x6894 | 0x6895 | 0x6897 | 0x6898 | 1        |
| ePWM4 | 0x68D2 | 0x68D4 | 0x68D5 | 0x68D7 | 0x68D8 | 1        |
| ePWM5 | 0x6912 | 0x6914 | 0x6915 | 0x6917 | 0x6918 | 1        |
| ePWM6 | 0x6952 | 0x6954 | 0x6955 | 0x6957 | 0x6958 | 1        |
| ePWM7 | 0x6992 | 0x6994 | 0x6995 | 0x6997 | 0x6998 | 1        |

Peripheral Frames



## 1.4.3 Device Emulation Registers

These registers are used to control the protection mode of the C28x CPU and to monitor some critical device signals. The registers are defined in Table 1-90.

|           | Tar              | Die 1-90. Devid | e Emulation Registers         |  |
|-----------|------------------|-----------------|-------------------------------|--|
| Name      | Address          | Size (x16)      | Description                   |  |
| DEVICECNF | 0x0880<br>0x0881 | 2               | Device Configuration Register |  |
| PARTID    | 0x0882           | 1               | Device Part ID Register       |  |
| REVID     | 0x0883           | 1               | Device Revision ID Register   |  |

## Table 1-90. Device Emulation Registers

## Figure 1-67. Device Configuration (DEVICECNF) Register

| 31 |          | 27   | 26   |          |          | 20       | 19         | 18 |          | 16 |
|----|----------|------|------|----------|----------|----------|------------|----|----------|----|
|    | Reserved | TRST |      | Reserved |          |          | ENPROT     |    | Reserved |    |
|    | R-0      | R-0  |      | R-0      |          |          | R/W-1      |    | R-111    |    |
|    |          |      |      |          |          |          |            |    |          |    |
| 15 |          |      |      |          | 5        | 4        | 3          | 2  |          | 0  |
| 15 |          | Rese | rved |          | 5<br>XRS | 4<br>Res | 3<br>VMAPS | 2  | Reserved | 0  |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-91. DEVICECNF Register Field Descriptions

| Bits  | Field    | Value | Description                                                                               |
|-------|----------|-------|-------------------------------------------------------------------------------------------|
| 31-28 | Reserved |       | Reserved                                                                                  |
| 27    | TRST     |       | Read status of TRST signal. Reading this bit gives the current status of the TRST signal. |
|       |          | 0     | No emulator is connected.                                                                 |
|       |          | 1     | An emulator is connected.                                                                 |
| 26:-0 | Reserved |       |                                                                                           |
| 19    | ENPROT   |       | Enable Write-Read Protection Mode Bit.                                                    |
|       |          | 0     | Disables write-read protection mode                                                       |
|       |          | 1     | Enables write-read protection for the address range 0x4000-0x7FFF                         |
| 18-6  | Reserved |       | Reserved                                                                                  |
| 5     | XRS      |       | Reset Input Signal Status. This is connected directly to the XRS input pin.               |
| 4     | Reserved |       | Reserved                                                                                  |
| 3     | VMAPS    |       | VMAP Configure Status. This indicates the status of VMAP.                                 |
| 2-0   | Reserved |       | Reserved                                                                                  |



|          | Figure 1-68 | . Part ID Register |   |
|----------|-------------|--------------------|---|
| 15       | 8           | 7                  | 0 |
| PARTTYPE |             | PARTNO             |   |
| R        |             | R                  |   |
|          |             |                    |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-92. PARTID Register Field Descriptions

| Field    | Value    | Description                                                                                                 |
|----------|----------|-------------------------------------------------------------------------------------------------------------|
| PARTTYPE | 0x01     | Defines F2805x device class.                                                                                |
| PARTNO   |          | These 8 bits specify the feature set of the device as follows:                                              |
|          | 0x05     | TMS320F28055PN                                                                                              |
|          | 0x04     | TMS320F28054PN                                                                                              |
|          | 0x03     | TMS320F28053PN                                                                                              |
|          | 0x02     | TMS320F28052PN                                                                                              |
|          | 0x01     | TMS320F28051PN                                                                                              |
|          | 0x00     | TMS320F28050PN                                                                                              |
|          | PARTTYPE | PARTTYPE         0x01           PARTNO         0x05           0x04         0x03           0x02         0x01 |

#### Figure 1-69. REVID Register

| 15                | 0 |
|-------------------|---|
| REVID             |   |
| R- <sup>(1)</sup> |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

<sup>(1)</sup> The reset value depends on the silicon revision as described in the register field description.

## Table 1-93. REVID Register Field Descriptions

| Bits | Field | Value  | Description                                                                                                                                                                                                          |
|------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | REVID |        | <sup>(1)</sup> These 16 bits specify the silicon revision number for the particular part. This number always starts with 0x0000 on the first revision of the silicon and is incremented on any subsequent revisions. |
|      |       | 0x0000 | Silicon Revision 0 - TMX                                                                                                                                                                                             |
|      |       | 0x0001 | Silicon Revision A - TMS                                                                                                                                                                                             |

<sup>(1)</sup> The reset value depends on the silicon revision as described in the register field description.



#### 1.4.4 Write-Followed-by-Read Protection

0x4000 - 0x7FFF is the memory address range for which CPU write followed by read operations are protected (operations occur in sequence rather then in their natural pipeline order). This is necessary protection for certain peripheral operations.

**Example:** The following lines of code perform a write to register 1 (REG1) location and then the next instruction performs a read from Register 2 (REG2) location. On the processor memory bus, with block protection disabled, the read operation is issued before the write as shown.

MOV @REG1,AL -----+ TBIT @REG2,#BIT\_X ------> Read +-----> Write

If block protection is enabled, then the read is stalled until the write occurs as shown:

MOV @REG1,AL -----+ TBIT @REG2,#BIT\_X -----+ +----> Write +---> Read



## 1.5 Peripheral Interrupt Expansion (PIE)

The peripheral interrupt expansion (PIE) block multiplexes numerous interrupt sources into a smaller set of interrupt inputs. The PIE block can support 96 individual interrupts that are grouped into blocks of eight. Each group is fed into one of 12 core interrupt lines (INT1 to INT12). Each of the 96 interrupts is supported by its own vector stored in a dedicated RAM block that you can modify. The CPU, upon servicing the interrupt, automatically fetches the appropriate interrupt vector. It takes nine CPU clock cycles to fetch the vector and save critical CPU registers. Therefore, the CPU can respond quickly to interrupt events. Prioritization of interrupts is controlled in hardware and software. Each individual interrupt can be enabled/disabled within the PIE block.

## 1.5.1 Overview of the PIE Controller

The 28x CPU supports one nonmaskable interrupt (NMI) and 16 maskable prioritized interrupt requests (INT1-INT14, RTOSINT, and DLOGINT) at the CPU level. The 28x devices have many peripherals and each peripheral is capable of generating one or more interrupts in response to many events at the peripheral level. Because the CPU does not have sufficient capacity to handle all peripheral interrupt requests at the CPU level, a centralized peripheral interrupt expansion (PIE) controller is required to arbitrate the interrupt requests from various sources such as peripherals and other external pins.

The PIE vector table is used to store the address (vector) of each interrupt service routine (ISR) within the system. There is one vector per interrupt source including all MUXed and nonMUXed interrupts. You populate the vector table during device initialization and you can update it during operation.

## 1.5.1.1 Interrupt Operation Sequence

Figure 1-70 shows an overview of the interrupt operation sequence for all multiplexed PIE interrupts. Interrupt sources that are not multiplexed are fed directly to the CPU.



#### Figure 1-70. Overview: Multiplexing of Interrupts Using the PIE Block



#### • Peripheral Level

An interrupt-generating event occurs in a peripheral. The interrupt flag (IF) bit corresponding to that event is set in a register for that particular peripheral.

If the corresponding interrupt enable (IE) bit is set, the peripheral generates an interrupt request to the PIE controller. If the interrupt is not enabled at the peripheral level, then the IF remains set until cleared by software. If the interrupt is enabled at a later time, and the interrupt flag is still set, the interrupt request is asserted to the PIE.

Interrupt flags within the peripheral registers must be manually cleared. See the peripheral reference guide for a specific peripheral for more information.

PIE Level

The PIE block multiplexes eight peripheral and external pin interrupts into one CPU interrupt. These interrupts are divided into 12 groups: PIE group 1 - PIE group 12. The interrupts within a group are multiplexed into one CPU interrupt. For example, PIE group 1 is multiplexed into CPU interrupt 1 (INT1) while PIE group 12 is multiplexed into CPU interrupt 12 (INT12). Interrupt sources connected to the remaining CPU interrupts are not multiplexed. For the nonmultiplexed interrupts, the PIE passes the request directly to the CPU.

For multiplexed interrupt sources, each interrupt group in the PIE block has an associated flag register (PIEIFRx) and enable (PIEIERx) register (x = PIE group 1 - PIE group 12). Each bit, referred to as y, corresponds to one of the 8 MUXed interrupts within the group. Thus PIEIFRx.y and PIEIERx.y correspond to interrupt y (y = 1-8) in PIE group x (x = 1-12). In addition, there is one acknowledge bit (PIEACK) for every PIE interrupt group referred to as PIEACKx (x = 1-12). Figure 1-71 illustrates the behavior of the PIE hardware under various PIEIFR and PIEIER register conditions.

Once the request is made to the PIE controller, the corresponding PIE interrupt flag (PIEIFRx.y) bit is set. If the PIE interrupt enable (PIEIERx.y) bit is also set for the given interrupt then the PIE checks the corresponding PIEACKx bit to determine if the CPU is ready for an interrupt from that group. If the PIEACKx bit is clear for that group, then the PIE sends the interrupt request to the CPU. If PIEACKx is set, then the PIE waits until it is cleared to send the request for INTx. See Section 6.3 for details.

CPU Level

Once the request is sent to the CPU, the CPU level interrupt flag (IFR) bit corresponding to INTx is set. After a flag has been latched in the IFR, the corresponding interrupt is not serviced until it is appropriately enabled in the CPU interrupt enable (IER) register or the debug interrupt enable register (DBGIER) and the global interrupt mask (INTM) bit.





Figure 1-71. Typical PIE/CPU Interrupt Response - INTx.y

A For multiplexed interrupts, the PIE responds with the highest priority interrupt that is both flagged and enabled. If there is no interrupt both flagged and enabled, then the highest priority interrupt within the group (INTx.1 where x is the PIE group) is used. See Section Section 1.5.3.3 for details.

As shown in Table 1-94, the requirements for enabling the maskable interrupt at the CPU level depends on the interrupt handling process being used. In the standard process, which happens most of the time, the DBGIER register is not used. When the 28x is in real-time emulation mode and the CPU is halted, a different process is used. In this special case, the DBGIER is used and the INTM bit is ignored. If the DSP is in real-time mode and the CPU is running, the standard interrupt-handling process applies.

|                                  | 5                               |  |
|----------------------------------|---------------------------------|--|
| Interrupt Handling Process       | Interrupt Enabled If            |  |
| Standard                         | INTM = 0 and bit in IER is 1    |  |
| DSP in real-time mode and halted | Bit in IER is 1 and DBGIER is 1 |  |

#### Table 1-94. Enabling Interrupt



The CPU then prepares to service the interrupt. This preparation process is described in detail in *TMS320C28x CPU and Instruction Set Reference Guide* (literature number <u>SPRU430</u>). In preparation, the corresponding CPU IFR and IER bits are cleared, EALLOW and LOOP are cleared, INTM and DBGM are set, the pipeline is flushed and the return address is stored, and the automatic context save is performed. The vector of the ISR is then fetched from the PIE module. If the interrupt request comes from a multiplexed interrupt, the PIE module uses the group PIEIERx and PIEIFRx registers to decode which interrupt needs to be serviced. This decode process is described in detail in Section 1.5.3.3.

The address for the interrupt service routine that is executed is fetched directly from the PIE interrupt vector table. There is one 32-bit vector for each of the possible 96 interrupts within the PIE. Interrupt flags within the PIE module (PIEIFRx.y) are automatically cleared when the interrupt vector is fetched. The PIE acknowledge bit for a given interrupt group, however, must be cleared manually when ready to receive more interrupts from the PIE group.

## 1.5.2 Vector Table Mapping

On these devices, the interrupt vector table can be mapped to four distinct locations in memory. In practice only the PIE vector table mapping is used.

| VMAP:    | VMAP is found in Status Register 1 ST1 (bit 3). A device reset sets this bit to 1. The state of this bit can be modified by writing to ST1 or by SETC/CLRC VMAP instructions. For normal operation leave this bit set.                                                                     |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| M0M1MAP: | M0M1MAP is found in Status Register 1 ST1 (bit 11). A device reset sets this bit to 1. The state of this bit can be modified by writing to ST1 or by SETC/CLRC M0M1MAP instructions. For normal device operation, this bit should remain set. M0M1MAP = 0 is reserved for TI testing only. |
| ENPIE:   | ENPIE is found in PIECTRL Register (bit 0). The default value of this bit, on reset, is set to 0 (PIE disabled). The state of this bit can be modified after reset by writing to the PIECTRL register (address 0x0000 0CE0).                                                               |

This vector mapping is controlled by the following mode bits/signals:

Using these bits and signals the possible vector table mappings are shown in Table 1-95.

#### Table 1-95. Interrupt Vector Table Mapping

| Vector MAPS              | Vectors Fetched From | Address Range       | VMAP | M0M1MAP | ENPIE |
|--------------------------|----------------------|---------------------|------|---------|-------|
| M1 Vector <sup>(1)</sup> | M1 SARAM Block       | 0x000000 - 0x00003F | 0    | 0       | Х     |
| M0 Vector <sup>(1)</sup> | M0 SARAM Block       | 0x000000 - 0x00003F | 0    | 1       | Х     |
| BROM Vector              | Boot ROM Block       | 0x3FFFC0 - 0x3FFFFF | 1    | Х       | 0     |
| PIE Vector               | PIE Block            | 0x000D00 - 0x000DFF | 1    | Х       | 1     |

<sup>(1)</sup> Vector map M0 and M1 Vector is a reserved mode only. On the 28x devices these are used as SARAM.

The M1 and M0 vector table mapping are reserved for TI testing only. When using other vector mappings, the M0 and M1 memory blocks are treated as SARAM blocks and can be used freely without any restrictions.

After a device reset operation, the vector table is mapped as shown in Table 1-96.

#### Table 1-96. Vector Table Mapping After Reset Operation

|                                                                                        | (1) (1) | MOM1MAP <sup>(1)</sup> | VMAP <sup>(1)</sup> | Address Range       | Reset Fetched From | Vector MAPS                |
|----------------------------------------------------------------------------------------|---------|------------------------|---------------------|---------------------|--------------------|----------------------------|
| BROM Vector (2)         Boot ROM Block         0x3FFFC0 - 0x3FFFFF         1         1 | 0       | 1                      | 1                   | 0x3FFFC0 - 0x3FFFFF | Boot ROM Block     | BROM Vector <sup>(2)</sup> |

<sup>(1)</sup> On the 28x devices, the VMAP and M0M1MAP modes are set to 1 on reset. The ENPIE mode is forced to 0 on reset.

<sup>(2)</sup> The reset vector is always fetched from the boot ROM.



After the reset and boot is complete, the PIE vector table should be initialized by the user's code. Then the application enables the PIE vector table. From that point on the interrupt vectors are fetched from the PIE vector table. Note: when a reset occurs, the reset vector is always fetched from the vector table as shown in Table 1-96. After a reset the PIE vector table is always disabled.

Figure 1-72 illustrates the process by which the vector table mapping is selected.



Figure 1-72. Reset Flow Diagram

A The compatibility operating mode of the 28x CPU is determined by a combination of the OBJMODE and AMODE bits in Status Register 1 (ST1):

| Operating Mode              | OBJMODE | AMODE |                    |
|-----------------------------|---------|-------|--------------------|
| C28x Mode                   | 1       | 0     |                    |
| 24x/240xA Source-Compatible | 1       | 1     |                    |
| C27x Object-Compatible      | 0       | 0     | (Default at reset) |

B The reset vector is always fetched from the boot ROM.



#### 1.5.3 Interrupt Sources

Figure 1-73 shows how the various interrupt sources are multiplexed within the devices. This multiplexing (MUX) scheme may not be exactly the same on all 28x devices. See the data manual of your particular device for details.



Figure 1-73. PIE Interrupt Sources and External Interrupts XINT1/XINT2/XINT3



### 1.5.3.1 Procedure for Handling Multiplexed Interrupts

The PIE module multiplexes eight peripheral and external pin interrupts into one CPU interrupt. These interrupts are divided into 12 groups: PIE group 1 - PIE group 12. Each group has an associated enable PIEIER and flag PIEIFR register. These registers are used to control the flow of interrupts to the CPU. The PIE module also uses the PIEIER and PIEIFR registers to decode to which interrupt service routine the CPU should branch.

There are three main rules that should be followed when clearing bits within the PIEIFR and the PIEIER registers:

## Rule 1: Never clear a PIEIFR bit by software

An incoming interrupt may be lost while a write or a read-modify-write operation to the PIEIFR register takes place. To clear a PIEIFR bit, the pending interrupt must be serviced. If you want to clear the PIEIFR bit without executing the normal service routine, then use the following procedure:

- 1. Set the EALLOW bit to allow modification to the PIE vector table.
- 2. Modify the PIE vector table so that the vector for the peripheral's service routine points to a temporary ISR. This temporary ISR will only perform a return from interrupt (IRET) operation.
- 3. Enable the interrupt so that the interrupt will be serviced by the temporary ISR.
- 4. After the temporary interrupt routine is serviced, the PIEIFR bit will be clear
- 5. Modify the PIE vector table to re-map the peripheral's service routine to the proper service routine.
- 6. Clear the EALLOW bit.

### Rule 2: Procedure for software-prioritizing interrupts

Use the method found in the C/C++ Header Files and Peripheral Examples in C (literature number <u>SPRC892</u>).

- (a) Use the CPU IER register as a global priority and the individual PIEIER registers for group priorities. In this case the PIEIER register is only modified within an interrupt. In addition, only the PIEIER for the same group as the interrupt being serviced is modified. This modification is done while the PIEACK bit holds additional interrupts back from the CPU.
- (b) Never disable a PIEIER bit for a group when servicing an interrupt from an unrelated group.

#### Rule 3: Disabling interrupts using PIEIER

If the PIEIER registers are used to enable and then later disable an interrupt then the procedure described in Section 1.5.3.2 must be followed.



#### 1.5.3.2 Procedures for Enabling And Disabling Multiplexed Peripheral Interrupts

The proper procedure for enabling or disabling an interrupt is by using the peripheral interrupt enable/disable flags. The primary purpose of the PIEIER and CPU IER registers is for software prioritization of interrupts within the same PIE interrupt group. The software package C/C++ Header Files and Peripheral Examples in C (literature number <u>SPRC892</u>). C/C++ Header Files and Peripheral Examples in C (literature number <u>SPRC530</u>) includes an example that illustrates this method of software prioritizing interrupts.

Should bits within the PIEIER registers need to be cleared outside of this context, one of the following two procedures should be followed. The first method preserves the associated PIE flag register so that interrupts are not lost. The second method clears the associated PIE flag register.

# Method 1: Use the PIEIERx register to disable the interrupt and preserve the associated PIEIFRx flags.

To clear bits within a PIEIERx register while preserving the associated flags in the PIEIFRx register, the following procedure should be followed:

- Step a. Disable global interrupts (INTM = 1).
- Step b. Clear the PIEIERx.y bit to disable the interrupt for a given peripheral. This can be done for one or more peripherals within the same group.
- Step c. Wait 5 cycles. This delay is required to be sure that any interrupt that was incoming to the CPU has been flagged within the CPU IFR register.
- Step d. Clear the CPU IFRx bit for the peripheral group. This is a safe operation on the CPU IFR register.
- Step e. Clear the PIEACKx bit for the peripheral group.
- Step f. Enable global interrupts (INTM = 0).

#### Method 2: Use the PIEIERx register to disable the interrupt and clear the associated PIEIFRx flags.

To perform a software reset of a peripheral interrupt and clear the associated flag in the PIEIFRx register and CPU IFR register, the following procedure should be followed:

- Step 1. Disable global interrupts (INTM = 1).
- Step 2. Set the EALLOW bit.
- Step 3. Modify the PIE vector table to temporarily map the vector of the specific peripheral interrupt to a empty interrupt service routine (ISR). This empty ISR will only perform a return from interrupt (IRET) instruction. This is the safe way to clear a single PIEIFRx.y bit without losing any interrupts from other peripherals within the group.
- Step 4. Disable the peripheral interrupt at the peripheral register.
- Step 5. Enable global interrupts (INTM = 0).
- Step 6. Wait for any pending interrupt from the peripheral to be serviced by the empty ISR routine.
- Step 7. Disable global interrupts (INTM = 1).
- Step 8. Modify the PIE vector table to map the peripheral vector back to its original ISR.
- Step 9. Clear the EALLOW bit.
- Step 10. Disable the PIEIER bit for given peripheral.
- Step 11. Clear the IFR bit for given peripheral group (this is safe operation on CPU IFR register).
- Step 12. Clear the PIEACK bit for the PIE group.
- Step 13. Enable global interrupts.

## 1.5.3.3 Flow of a Multiplexed Interrupt Request From a Peripheral to the CPU

Figure 1-74 shows the flow with the steps shown in circled numbers. Following the diagram, the steps are described.



### Figure 1-74. Multiplexed Interrupt Request Flow Diagram

- Step 1. Any peripheral or external interrupt within the PIE group generates an interrupt. If interrupts are enabled within the peripheral module then the interrupt request is sent to the PIE module.
- Step 2. The PIE module recognizes that interrupt y within PIE group x (INTx.y) has asserted an interrupt and the appropriate PIE interrupt flag bit is latched: PIEIFRx.y = 1.
- Step 3. For the interrupt request to be sent from the PIE to the CPU, both of the following conditions must be true:
  - (a) The proper enable bit must be set (PIEIERx.y = 1) and
  - (b) The PIEACKx bit for the group must be clear.
- Step 4. If both conditions in 3a and 3b are true, then an interrupt request is sent to the CPU and the acknowledge bit is again set (PIEACKx = 1). The PIEACKx bit will remain set until you clear it to indicate that additional interrupts from the group can be sent from the PIE to the CPU.
- Step 5. The CPU interrupt flag bit is set (CPU IFRx = 1) to indicate a pending interrupt x at the CPU level.
- Step 6. If the CPU interrupt is enabled (CPU IER bit x = 1, or DBGIER bit x = 1) AND the global interrupt mask is clear (INTM = 0) then the CPU will service the INTx.
- Step 7. The CPU recognizes the interrupt and performs the automatic context save, clears the IER bit, sets INTM, and clears EALLOW. All of the steps that the CPU takes in order to prepare to service the interrupt are documented in the *TM S320C28x DSP CPU and Instruction Set Reference Guide* (literature number SPRU430).
- Step 8. The CPU will then request the appropriate vector from the PIE.
- Step 9. For multiplexed interrupts, the PIE module uses the current value in the PIEIERx and PIEIFRx registers to decode which vector address should be used. There are two possible cases:
  - (a) The vector for the highest priority interrupt within the group that is both enabled in the



Peripheral Interrupt Expansion (PIE)

www.ti.com

PIEIERx register, and flagged as pending in the PIEIFRx is fetched and used as the branch address. In this manner if an even higher priority enabled interrupt was flagged after Step 7, it will be serviced first.

- (b) If no flagged interrupts within the group are enabled, then the PIE will respond with the vector for the highest priority interrupt within that group. That is the branch address used for INTx.1. This behavior corresponds to the 28x TRAP or INT instructions.
- **NOTE:** Because the PIEIERx register is used to determine which vector will be used for the branch, you must take care when clearing bits within the PIEIERx register. The proper procedure for clearing bits within a PIEIERx register is described in Section 1.5.3.2. Failure to follow these steps can result in changes occurring to the PIEIERx register after an interrupt has been passed to the CPU at Step 5 in Figure 6-5. In this case, the PIE will respond as if a TRAP or INT instruction was executed unless there are other interrupts both pending and enabled.

At this point, the PIEIFRx.y bit is cleared and the CPU branches to the vector of the interrupt fetched from the PIE.

#### 1.5.3.4 The PIE Vector Table

The PIE vector table (see Table 1-98) consists of a 256 x 16 SARAM block that can also be used as RAM (in data space only) if the PIE block is not in use. The PIE vector table contents are undefined on reset. The CPU fixes interrupt priority for INT1 to INT12. The PIE controls priority for each group of eight interrupts. For example, if INT1.1 should occur simultaneously with INT8.1, both interrupts are presented to the CPU simultaneously by the PIE block, and the CPU services INT1.1 first. If INT1.1 should occur simultaneously with INT8.1, both interrupts are presented to the CPU simultaneously with INT1.8, then INT1.1 is sent to the CPU first and then INT1.8 follows. Interrupt prioritization is performed during the vector fetch portion of the interrupt processing.

When the PIE is enabled, a TRAP #1 through TRAP #12 or an INTR INT1 to INTR INT12 instruction transfers program control to the interrupt service routine corresponding to the first vector within the PIE group. For example: TRAP #1 fetches the vector from INT1.1, TRAP #2 fetches the vector from INT2.1 and so forth. Similarly an OR IFR, #16-bit operation causes the vector to be fetched from INTR1.1 to INTR12.1 locations, if the respective interrupt flag is set. All other TRAP, INTR, OR IFR,#16-bit operations fetch the vector from the respective table location. The vector table is EALLOW protected.

Out of the 96 possible MUXed interrupts in Table 1-97, 43 interrupts are currently used. The remaining interrupts are reserved for future devices. These reserved interrupts can be used as software interrupts if they are enabled at the PIEIFRx level, provided none of the interrupts within the group is being used by a peripheral. Otherwise, interrupts coming from peripherals may be lost by accidentally clearing their flags when modifying the PIEIFR.

To summarize, there are two safe cases when the reserved interrupts can be used as software interrupts:

- 1. No peripheral within the group is asserting interrupts.
- 2. No peripheral interrupts are assigned to the group. For example, PIE group 11 and 12 do not have any peripherals attached to them.

The interrupt grouping for peripherals and external interrupts connected to the PIE module is shown in Table 1-97. Each row in the table shows the 8 interrupts multiplexed into a particular CPU interrupt. The entire PIE vector table, including both MUXed and non-MUXed interrupts, is shown in Table 1-98.

|        |          |             |             | •           | •           |             |             |             |
|--------|----------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
|        | INTx.8   | INTx.7      | INTx.6      | INTx.5      | INTx.4      | INTx.3      | INTx.2      | INTx.1      |
| INT1.y | WAKEINT  | TINT0       | ADCINT9     | XINT2       | XINT1       | Reserved    | ADCINT2     | ADCINT1     |
|        | (LPM/WD) | (TIMER 0)   | (ADC)       | Ext. int. 2 | Ext. int. 1 | -           | (ADC)       | (ADC)       |
|        | 0xD4E    | 0xD4C       | 0xD4A       | 0xD48       | 0xD46       | 0xD44       | 0xD42       | 0xD40       |
| INT2.y | Reserved | EPWM7_TZINT | EPWM6_TZINT | EPWM5_TZINT | EPWM4_TZINT | EPWM3_TZINT | EPWM2_TZINT | EPWM1_TZINT |
|        | -        | (ePWM7)     | (ePWM6)     | (ePWM5)     | (ePWM4)     | (ePWM3)     | (ePWM2)     | (ePWM1)     |
|        | 0xD5E    | 0xD5C       | 0xD5A       | 0xD58       | 0xD56       | 0xD54       | 0xD52       | 0xD50       |
| INT3.y | Reserved | EPWM7_INT   | EPWM6_INT   | EPWM5_INT   | EPWM4_INT   | EPWM3_INT   | EPWM2_INT   | EPWM1_INT   |
|        | -        | (EPWM7)     | (ePWM6)     | (ePWM5)     | (ePWM4)     | (ePWM3)     | (ePWM2)     | (ePWM1)     |
|        | 0xD6E    | 0xD6C       | 0xD6A       | 0xD68       | 0xD66       | 0xD64       | 0xD62       | 0xD60       |

#### Table 1-97. PIE MUXed Peripheral Interrupt Vector Table

|         | INTx.8    | INTx.7    | INTx.6     | INTx.5     | INTx.4    | INTx.3    | INTx.2    | INTx.1      |
|---------|-----------|-----------|------------|------------|-----------|-----------|-----------|-------------|
| NT4.y   | Reserved  | Reserved  | Reserved   | Reserved   | Reserved  | Reserved  | Reserved  | ECAP1_IN1   |
|         | -         | -         | -          | -          | -         | -         | -         | (eCAP1)     |
|         | 0xD7E     | 0xD7C     | 0xD7A      | 0xD78      | 0xD76     | 0xD74     | 0xD72     | 0xD70       |
| INT5.y  | Reserved  | Reserved  | Reserved   | Reserved   | Reserved  | Reserved  | Reserved  | EQEP1_IN    |
|         | -         | -         | -          | -          | -         | -         | -         | (eQEP1)     |
|         | 0xD8E     | 0xD8C     | 0xD8A      | 0xD88      | 0xD86     | 0xD84     | 0xD82     | 0xD80       |
| INT6.y  | Reserved  | Reserved  | Reserved   | Reserved   | Reserved  | Reserved  | SPITXINTA | SPIRXINT    |
|         | -         | -         | -          | -          | -         | -         | (SPI-A)   | (SPI-A)     |
|         | 0xD9E     | 0xD9C     | 0xD9A      | 0xD98      | 0xD96     | 0xD94     | 0xD92     | 0xD90       |
| INT7.y  | Reserved  | Reserved  | Reserved   | Reserved   | Reserved  | Reserved  | Reserved  | Reserved    |
|         | -         | -         | -          | -          | -         | -         | -         | -           |
|         | 0xDAE     | 0xDAC     | 0xDAA      | 0xDA8      | 0xDA6     | 0xDA4     | 0xDA2     | 0xDA0       |
| INT8.y  | Reserved  | Reserved  | SCIRXINTB  | SCIRXINTC  | Reserved  | Reserved  | I2CINT2A  | I2CINT1A    |
|         | -         | -         | (SCI-C)    | (SCI-C)    | -         | -         | (I2C-A)   | (I2C-A)     |
|         | 0xDBE     | 0xDBC     | 0xDBA      | 0xDB8      | 0xDB6     | 0xDB4     | 0xDB2     | 0xDB0       |
| INT9.y  | Reserved  | Reserved  | ECANA_INT0 | ECANA_INT1 | SCITXINTB | SCIRXINTB | SCITXINTA | SCIRXINT    |
|         | -         | -         | (CAN-A)    | (CAN-A)    | (SCI-B)   | (SCI-B)   | (SCI-A)   | (SCI-A)     |
|         | 0xDCE     | 0xDCC     | 0xDCA      | 0xDC8      | 0xDC6     | 0xDC4     | 0xDC2     | 0xDC0       |
| INT10.y | ADCINT8   | ADCINT7   | ADCINT6    | ADCINT5    | ADCINT4   | ADCINT3   | ADCINT2   | ADCINT1     |
|         | (ADC)     | (ADC)     | (ADC)      | (ADC)      | (ADC)     | (ADC)     | (ADC)     | (ADC)       |
|         | 0xDDE     | 0xDDC     | 0xDDA      | 0xDD8      | 0xDD6     | 0xDD4     | 0xDD2     | 0xDD0       |
| INT11.y | CLA1_INT8 | CLA1_INT7 | CLA1_INT6  | CLA1_INT5  | CLA1_INT4 | CLA1_INT3 | CLA1_INT2 | CLA1_INT    |
|         | (CLA)     | (CLA)     | (CLA)      | (CLA)      | (CLA)     | (CLA)     | (CLA)     | (CLA)       |
|         | 0xDEE     | 0xDEC     | 0xDEA      | 0xDE8      | 0xDE6     | 0xDE4     | 0xDE2     | 0xDE0       |
| INT12.y | LUF       | LVF       | Reserved   | Reserved   | Reserved  | Reserved  | Reserved  | XINT3       |
|         | (CLA)     | (CLA)     | -          | -          | -         | -         | -         | Ext. Int. 3 |
|         | 0xDFE     | 0xDFC     | 0xDFA      | 0xDF8      | 0xDF6     | 0xDF4     | 0xDF2     | 0xDF0       |

### Table 1-97. PIE MUXed Peripheral Interrupt Vector Table (continued)

#### Table 1-98. PIE Vector Table

| Name    | VECTOR<br>ID | Address <sup>(1)</sup> | Size (x16) | Description <sup>(2)</sup>                                       | CPU<br>Priority | PIE Group<br>Priority |
|---------|--------------|------------------------|------------|------------------------------------------------------------------|-----------------|-----------------------|
| Reset   | 0            | 0x0000 0D00            | 2          | Reset is always fetched from location 0x003F FFC0 in boot ROM.   | 1<br>(highest)  | -                     |
| INT1    | 1            | 0x0000 0D02            | 2          | Not used. See PIE Group 1                                        | 5               | -                     |
| INT2    | 2            | 0x0000 0D04            | 2          | Not used. See PIE Group 2                                        | 6               | -                     |
| INT3    | 3            | 0x0000 0D06            | 2          | Not used. See PIE Group 3                                        | 7               | -                     |
| INT4    | 4            | 0x0000 0D08            | 2          | Not used. See PIE Group 4                                        | 8               | -                     |
| INT5    | 5            | 0x0000 0D0A            | 2          | Not used. See PIE Group 5                                        | 9               | -                     |
| INT6    | 6            | 0x0000 0D0C            | 2          | Not used. See PIE Group 6                                        | 10              | -                     |
| INT7    | 7            | 0x0000 0D0E            | 2          | Not used. See PIE Group 7                                        | 11              | -                     |
| INT8    | 8            | 0x0000 0D10            | 2          | Not used. See PIE Group 8                                        | 12              | -                     |
| INT9    | 9            | 0x0000 0D12            | 2          | Not used. See PIE Group 9                                        | 13              | -                     |
| INT10   | 10           | 0x0000 0D14            | 2          | Not used. See PIE Group 10                                       | 14              | -                     |
| INT11   | 11           | 0x0000 0D16            | 2          | Not used. See PIE Group 11                                       | 15              | -                     |
| INT12   | 12           | 0x0000 0D18            | 2          | Not used. See PIE Group 12                                       | 16              | -                     |
| INT13   | 13           | 0x0000 0D1A            | 2          | 2 External Interrupt 13 (XINT13) or<br>CPU-Timer1 <sup>(3)</sup> |                 | -                     |
| INT14   | 14           | 0x0000 0D1C            | 2          | CPU-Timer2<br>(for TI/RTOS use)                                  | 18              | -                     |
| DATALOG | 15           | 0x0000 0D1E            | 2          | CPU Data Logging Interrupt                                       | 19 (lowest)     | -                     |

<sup>(1)</sup> Reset is always fetched from location 0x003F FFC0 in boot ROM.

<sup>(2)</sup> All the locations within the PIE vector table are EALLOW protected.

<sup>(3)</sup> CPU-Timer1 is reserved for TI software use. The interrupt XINT13, however, can be freely used by customer applications.

TEXAS INSTRUMENTS

### Peripheral Interrupt Expansion (PIE)

www.ti.com

| Name        | VECTOR<br>ID  | Address <sup>(1)</sup> | Size (x16) | Description <sup>(2)</sup> |                         | CPU<br>Priority | PIE Group<br>Priority |
|-------------|---------------|------------------------|------------|----------------------------|-------------------------|-----------------|-----------------------|
| RTOSINT     | 16            | 0x0000 0D20            | 2          | CPU Real-Time OS           | S Interrupt             | 4               | -                     |
| EMUINT      | 17            | 0x0000 0D22            | 2          | CPU Emulation Inte         | CPU Emulation Interrupt |                 | -                     |
| NMI         | 18            | 0x0000 0D24            | 2          | External Non-Mask          | able Interrupt          | 3               | -                     |
| ILLEGAL     | 19            | 0x0000 0D26            | 2          | Illegal Operation          |                         | -               | -                     |
| USER1       | 20            | 0x0000 0D28            | 2          | User-Defined Trap          |                         | -               | -                     |
| USER2       | 21            | 0x0000 0D2A            | 2          | User Defined Trap          |                         | -               | -                     |
| USER3       | 22            | 0x0000 0D2C            | 2          | User Defined Trap          |                         | -               | -                     |
| USER4       | 23            | 0x0000 0D2E            | 2          | User Defined Trap          |                         | -               | -                     |
| USER5       | 24            | 0x0000 0D30            | 2          | User Defined Trap          |                         | -               | -                     |
| USER6       | 25            | 0x0000 0D32            | 2          | User Defined Trap          |                         | -               | -                     |
| USER7       | 26            | 0x0000 0D34            | 2          | User Defined Trap          |                         | -               | -                     |
| USER8       | 27            | 0x0000 0D36            | 2          | User Defined Trap          |                         | -               | -                     |
| USER9       | 28            | 0x0000 0D38            | 2          | User Defined Trap          |                         | -               | -                     |
| USER10      | 29            | 0x0000 0D3A            | 2          | User Defined Trap          |                         | -               | -                     |
| USER11      | 30            | 0x0000 0D3C            | 2          | User Defined Trap          |                         | -               | -                     |
| USER12      | 31            | 0x0000 0D3E            | 2          | User Defined Trap          |                         | -               | -                     |
| PIE Group 1 | Vectors - MUX | ed into CPU INT1       |            | · ·                        |                         |                 |                       |
| INT1.1      | 32            | 0x0000 0D40            | 2          | ADCINT1                    | (ADC)                   | 5               | 1 (highest)           |
| INT1.2      | 33            | 0x0000 0D42            | 2          | ADCINT2                    | (ADC)                   | 5               | 2                     |
| INT1.3      | 34            | 0x0000 0D44            | 2          | Reserved                   | × ,                     | 5               | 3                     |
| INT1.4      | 35            | 0x0000 0D46            | 2          | XINT1                      |                         | 5               | 4                     |
| INT1.5      | 36            | 0x0000 0D48            | 2          | XINT2                      |                         | 5               | 5                     |
| INT1.6      | 37            | 0x0000 0D4A            | 2          | ADCINT9 (ADC)              |                         | 5               | 6                     |
| INT1.7      | 38            | 0x0000 0D4C            | 2          | TINT0                      | (CPU-<br>Timer0)        | 5               | 7                     |
| INT1.8      | 39            | 0x0000 0D4E            | 2          | WAKEINT                    | (LPM/WD)                | 5               | 8 (lowest)            |
|             |               | ed into CPU INT2       |            |                            |                         | _               |                       |
| INT2.1      | 40            | 0x0000 0D50            | 2          | EPWM1_TZINT                | (EPWM1)                 | 6               | 1 (highest            |
| INT2.2      | 41            | 0x0000 0D52            | 2          | EPWM2_TZINT                | (EPWM2)                 | 6               | 2                     |
| INT2.3      | 42            | 0x0000 0D54            | 2          | EPWM3_TZINT                | (EPWM3)                 | 6               | 3                     |
| INT2.4      | 43            | 0x0000 0D56            | 2          | EPWM4_TZINT                | (EPWM4)                 | 6               | 4                     |
| INT2.5      | 44            | 0x0000 0D58            | 2          | EPWM5_TZINT                | (EPWM5)                 | 6               | 5                     |
| INT2.6      | 45            | 0x0000 0D5A            | 2          | EPWM6_TZINT                | (EPWM6)                 | 6               | 6                     |
| INT2.7      | 46            | 0x0000 0D5C            | 2          | EPWM7_TZINT                | (EPWM7)                 | 6               | 7                     |
| INT2.8      | 47            | 0x0000 0D5E            | 2          | Reserved                   |                         | 6               | 8 (lowest)            |
| PIE Group 3 | Vectors - MUX | ed into CPU INT3       |            |                            |                         |                 |                       |
| INT3.1      | 48            | 0x0000 0D60            | 2          | EPWM1_INT                  | (EPWM1)                 | 7               | 1 (highest)           |
| INT3.2      | 49            | 0x0000 0D62            | 2          | EPWM2_INT                  | (EPWM2)                 | 7               | 2                     |
| INT3.3      | 50            | 0x0000 0D64            | 2          | EPWM3_INT                  | (EPWM3)                 | 7               | 3                     |
| INT3.4      | 51            | 0x0000 0D66            | 2          | EPWM4_INT (EPWM4)          |                         | 7               | 4                     |
| INT3.5      | 52            | 0x0000 0D68            | 2          | EPWM5_INT (EPWM5)          |                         | 7               | 5                     |
| INT3.6      | 53            | 0x0000 0D6A            | 2          | EPWM6_INT                  | (EPWM6)                 | 7               | 6                     |
| INT3.7      | 54            | 0x0000 0D6C            | 2          | EPWM7_INT                  | (EPWM7)                 | 7               | 7                     |
| INT3.8      | 55            | 0x0000 0D6E            | 2          | Reserved                   | -                       | 7               | 8 (lowest)            |
| PIE Group 4 | Vectors - MUX | ed into CPU INT4       |            |                            |                         |                 |                       |
| INT4.1      | 56            | 0x0000 0D70            | 2          | ECAP1_INT                  | (ECAP1)                 | 8               | 1 (highest)           |
| INT4.2      | 57            | 0x0000 0D72            | 2          | Reserved                   | -                       | 8               | 2                     |

## Table 1-98. PIE Vector Table (continued)

| Name      | VECTOR<br>ID      | Address <sup>(1)</sup> | Size (x16) | Description <sup>(2)</sup> |                      | CPU<br>Priority | PIE Group<br>Priority |
|-----------|-------------------|------------------------|------------|----------------------------|----------------------|-----------------|-----------------------|
| INT4.3    | 58                | 0x0000 0D74            | 2          | Reserved                   | -                    | 8               | 3                     |
| INT4.4    | 59                | 0x0000 0D76            | 2          | Reserved                   | -                    | 8               | 4                     |
| INT4.5    | 60                | 0x0000 0D78            | 2          | Reserved                   | -                    | 8               | 5                     |
| INT4.6    | 61                | 0x0000 0D7A            | 2          | Reserved                   | -                    | 8               | 6                     |
| INT4.7    | 62                | 0x0000 0D7C            | 2          | Reserved                   | -                    | 8               | 7                     |
| INT4.8    | 63                | 0x0000 0D7E            | 2          | Reserved                   | -                    | 8               | 8 (lowest)            |
| PIE Group | 5 Vectors - MUX   | ed into CPU INT5       |            |                            |                      |                 |                       |
| INT5.1    | 64                | 0x0000 0D80            | 2          | EQEP1_INT                  | (EQEP1)              | 9               | 1 (highest)           |
| INT5.2    | 65                | 0x0000 0D82            | 2          | Reserved                   | -                    | 9               | 2                     |
| INT5.3    | 66                | 0x0000 0D84            | 2          | Reserved                   | -                    | 9               | 3                     |
| INT5.4    | 67                | 0x0000 0D86            | 2          | Reserved                   | -                    | 9               | 4                     |
| INT5.5    | 68                | 0x0000 0D88            | 2          | Reserved                   | -                    | 9               | 5                     |
| INT5.6    | 69                | 0x0000 0D8A            | 2          | Reserved                   | -                    | 9               | 6                     |
| INT5.7    | 70                | 0x0000 0D8C            | 2          | Reserved                   | -                    | 9               | 7                     |
| INT5.8    | 71                | 0x0000 0D8E            | 2          | Reserved                   | -                    | 9               | 8 (lowest)            |
| PIE Group | 6 Vectors - MUX   | ed into CPU INT6       |            |                            |                      |                 |                       |
| INT6.1    | 72                | 0x0000 0D90            | 2          | SPIRXINTA                  | (SPI-A)              | 10              | 1 (highest)           |
| INT6.2    | 73                | 0x0000 0D92            | 2          | SPITXINTA                  | (SPI-A)              | 10              | 2                     |
| INT6.3    | 74                | 0x0000 0D94            | 2          | Reserved                   | -                    | 10              | 3                     |
| INT6.4    | 75                | 0x0000 0D96            | 2          | Reserved                   | -                    | 10              | 4                     |
| INT6.5    | 76                | 0x0000 0D98            | 2          | Reserved                   | -                    | 10              | 5                     |
| INT6.6    | 77                | 0x0000 0D9A            | 2          | Reserved                   | -                    | 10              | 6                     |
| INT6.7    | 78                | 0x0000 0D9C            | 2          | Reserved                   | -                    | 10              | 7                     |
| INT6.8    | 79                | 0x0000 0D9E            | 2          | Reserved                   | -                    | 10              | 8 (lowest)            |
|           | -                 | ed into CPU INT7       | _          |                            |                      |                 | 0 (.0.1000)           |
| INT7.1    | 80                | 0x0000 0DA0            | 2          | Reserved                   | -                    | 11              | 1 (highest)           |
| INT7.2    | 81                | 0x0000 0DA2            | 2          | Reserved                   | -                    | 11              | 2                     |
| INT7.3    | 82                | 0x0000 0DA4            | 2          | Reserved                   | -                    | 11              | 3                     |
| INT7.4    | 83                | 0x0000 0DA6            | 2          | Reserved                   | -                    | 11              | 4                     |
| INT7.5    | 84                | 0x0000 0DA8            | 2          | Reserved                   | -                    | 11              | 5                     |
| INT7.6    | 85                | 0x0000 0DAA            | 2          | Reserved                   | -                    | 11              | 6                     |
| INT7.7    | 86                | 0x0000 0DAC            | 2          | Reserved                   | -                    | 11              | 7                     |
| INT7.8    | 87                | 0x0000 0DAE            | 2          | Reserved                   | -                    | 11              | 8 (lowest)            |
|           |                   | ed into CPU INT8       | -          |                            |                      |                 | 0 (1011031)           |
| INT8.1    | 88                | 0x0000 0DB0            | 2          | I2CINT1A                   | (I <sup>2</sup> C-A) | 12              | 1 (highest)           |
| INT8.2    | 89                | 0x0000 0DB2            | 2          | I2CINT2A                   | (I <sup>2</sup> C-A) | 12              | 2                     |
| INT8.3    | 90                | 0x0000 0DB2            | 2          | Reserved                   | (1070)               | 12              | 3                     |
| INT8.4    | 91                | 0x0000 0DB4            | 2          | Reserved                   |                      | 12              | 4                     |
| INT8.5    | 92                | 0x0000 0DB8            | 2          | SCIRXINTC                  | (SCI-C)              | 12              | 5                     |
| INT8.6    | 93                | 0x0000 0DB8            | 2          | SCITXINTC                  | (SCI-C)              | 12              | 6                     |
|           |                   |                        |            |                            | (301-0)              |                 |                       |
| INT8.7    | 94                |                        | 2          | Reserved                   | -                    | 12<br>12        | 7<br>8 (lowost)       |
| INT8.8    | 95<br>Nootoro MUX | 0x0000 0DBE            | 2          | Reserved                   | -                    | 12              | 8 (lowest)            |
| -         |                   | ed into CPU INT9       | 0          |                            |                      | 40              | 1 (h:ahaat)           |
| INT9.1    | 96<br>07          | 0x0000 0DC0            | 2          | SCIRXINTA                  | (SCI-A)              | 13              | 1 (highest)           |
| INT9.2    | 97                | 0x0000 0DC2            | 2          | SCITXINTA                  | (SCI-A)              | 13              | 2                     |
| INT9.3    | 98                | 0x0000 0DC4            | 2          | SCIRXINTB                  | (SCI-B)              | 13              | 3                     |
| INT9.4    | 99                | 0x0000 0DC6            | 2          | SCITXINTC                  | (SCI-B)              | 13              | 4                     |

## Table 1-98. PIE Vector Table (continued)

SPRUHE5B–November 2012–Revised April 2013 Submit Documentation Feedback System Control and Interrupts 137



| Name        | VECTOR<br>ID    | Address <sup>(1)</sup> | Size (x16) | Description <sup>(2)</sup> |         | CPU<br>Priority | PIE Group<br>Priority |
|-------------|-----------------|------------------------|------------|----------------------------|---------|-----------------|-----------------------|
| INT9.5      | 100             | 0x0000 0DC8            | 2          | ECANAINT0                  | (CAN-A) | 13              | 5                     |
| INT9.6      | 101             | 0x0000 0DCA            | 2          | ECANAINT1                  | (CAN-A) | 13              | 6                     |
| INT9.7      | 102             | 0x0000 0DCC            | 2          | Reserved                   | -       | 13              | 7                     |
| INT9.8      | 103             | 0x0000 0DCE            | 2          | Reserved                   | -       | 13              | 8 (lowest)            |
| PIE Group 1 | 0 Vectors - MU  | (ed into CPU INT1      | )          |                            |         |                 |                       |
| INT10.1     | 104             | 0x0000 0DD0            | 2          | ADCINT1                    | (ADC)   | 14              | 1 (highest)           |
| INT10.2     | 105             | 0x0000 0DD2            | 2          | ADCINT2                    | (ADC)   | 14              | 2                     |
| INT10.3     | 106             | 0x0000 0DD4            | 2          | ADCINT3                    | (ADC)   | 14              | 3                     |
| INT10.4     | 107             | 0x0000 0DD6            | 2          | ADCINT4                    | (ADC)   | 14              | 4                     |
| INT10.5     | 108             | 0x0000 0DD8            | 2          | ADCINT5                    | (ADC)   | 14              | 5                     |
| INT10.6     | 109             | 0x0000 0DDA            | 2          | ADCINT6                    | (ADC)   | 14              | 6                     |
| INT10.7     | 110             | 0x0000 0DDC            | 2          | ADCINT7                    | (ADC)   | 14              | 7                     |
| INT10.8     | 111             | 0x0000 0DDE            | 2          | ADCINT8                    | (ADC)   | 14              | 8 (lowest)            |
| PIE Group 1 | 1 Vectors - MUX | (ed into CPU INT11     |            |                            |         |                 |                       |
| INT11.1     | 112             | 0x0000 0DE0            | 2          | CLA1_INT1                  | (CLA)   | 15              | 1 (highest)           |
| INT11.2     | 113             | 0x0000 0DE2            | 2          | CLA1_INT2                  | (CLA)   | 15              | 2                     |
| INT11.3     | 114             | 0x0000 0DE4            | 2          | CLA1_INT3                  | (CLA)   | 15              | 3                     |
| INT11.4     | 115             | 0x0000 0DE6            | 2          | CLA1_INT4                  | (CLA)   | 15              | 4                     |
| INT11.5     | 116             | 0x0000 0DE8            | 2          | CLA1_INT5                  | (CLA)   | 15              | 5                     |
| INT11.6     | 117             | 0x0000 0DEA            | 2          | CLA1_INT6                  | (CLA)   | 15              | 6                     |
| INT11.7     | 118             | 0x0000 0DEC            | 2          | CLA1_INT7                  | (CLA)   | 15              | 7                     |
| INT11.8     | 119             | 0x0000 0DEE            | 2          | CLA1_INT8                  | (CLA)   | 15              | 8 (lowest)            |
| PIE Group 1 | 2 Vectors - Mux | ed into CPU INT12      |            |                            |         |                 |                       |
| INT12.1     | 120             | 0x0000 0DF0            | 2          | XINT3                      | -       | 16              | 1 (highest)           |
| INT12.2     | 121             | 0x0000 0DF2            | 2          | Reserved                   | -       | 16              | 2                     |
| INT12.3     | 122             | 0x0000 0DF4            | 2          | Reserved                   | -       | 16              | 3                     |
| INT12.4     | 123             | 0x0000 0DF6            | 2          | Reserved                   | -       | 16              | 4                     |
| INT12.5     | 124             | 0x0000 0DF8            | 2          | Reserved                   | -       | 16              | 5                     |
| INT12.6     | 125             | 0x0000 0DFA            | 2          | Reserved                   | -       | 16              | 6                     |
| INT12.7     | 126             | 0x0000 0DFC            | 2          | LVF                        | (CLA)   | 16              | 7                     |
| INT12.8     | 127             | 0x0000 0DFE            | 2          | LUF                        | (CLA)   | 16              | 8 (lowest)            |

## Table 1-98. PIE Vector Table (continued)



## 1.5.4 PIE Configuration Registers

The registers controlling the functionality of the PIE block are shown in Table 1-99.

| Name     | Address       | Size (x16) | Description                      |
|----------|---------------|------------|----------------------------------|
| PIECTRL  | 0x0000 - 0CE0 | 1          | PIE, Control Register            |
| PIEACK   | 0x0000 - 0CE1 | 1          | PIE, Acknowledge Register        |
| PIEIER1  | 0x0000 - 0CE2 | 1          | PIE, INT1 Group Enable Register  |
| PIEIFR1  | 0x0000 - 0CE3 | 1          | PIE, INT1 Group Flag Register    |
| PIEIER2  | 0x0000 - 0CE4 | 1          | PIE, INT2 Group Enable Register  |
| PIEIFR2  | 0x0000 - 0CE5 | 1          | PIE, INT2 Group Flag Register    |
| PIEIER3  | 0x0000 - 0CE6 | 1          | PIE, INT3 Group Enable Register  |
| PIEIFR3  | 0x0000 - 0CE7 | 1          | PIE, INT3 Group Flag Register    |
| PIEIER4  | 0x0000 - 0CE8 | 1          | PIE, INT4 Group Enable Register  |
| PIEIFR4  | 0x0000 - 0CE9 | 1          | PIE, INT4 Group Flag Register    |
| PIEIER5  | 0x0000 - 0CEA | 1          | PIE, INT5 Group Enable Register  |
| PIEIFR5  | 0x0000 - 0CEB | 1          | PIE, INT5 Group Flag Register    |
| PIEIER6  | 0x0000 - 0CEC | 1          | PIE, INT6 Group Enable Register  |
| PIEIFR6  | 0x0000 - 0CED | 1          | PIE, INT6 Group Flag Register    |
| PIEIER7  | 0x0000 - 0CEE | 1          | PIE, INT7 Group Enable Register  |
| PIEIFR7  | 0x0000 - 0CEF | 1          | PIE, INT7 Group Flag Register    |
| PIEIER8  | 0x0000 - 0CF0 | 1          | PIE, INT8 Group Enable Register  |
| PIEIFR8  | 0x0000 - 0CF1 | 1          | PIE, INT8 Group Flag Register    |
| PIEIER9  | 0x0000 - 0CF2 | 1          | PIE, INT9 Group Enable Register  |
| PIEIFR9  | 0x0000 - 0CF3 | 1          | PIE, INT9 Group Flag Register    |
| PIEIER10 | 0x0000 - 0CF4 | 1          | PIE, INT10 Group Enable Register |
| PIEIFR10 | 0x0000 - 0CF5 | 1          | PIE, INT10 Group Flag Register   |
| PIEIER11 | 0x0000 - 0CF6 | 1          | PIE, INT11 Group Enable Register |
| PIEIFR11 | 0x0000 - 0CF7 | 1          | PIE, INT11 Group Flag Register   |
| PIEIER12 | 0x0000 - 0CF8 | 1          | PIE, INT12 Group Enable Register |
| PIEIFR12 | 0x0000 - 0CF9 | 1          | PIE, INT12 Group Flag Register   |

## Table 1-99. PIE Configuration and Control Registers

Peripheral Interrupt Expansion (PIE)



## 1.5.5 PIE Interrupt Registers

### Figure 1-75. PIECTRL Register (Address 0xCE0)

| 15      | 1 | 0     |
|---------|---|-------|
| PIEVECT |   | ENPIE |
| R-0     |   | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-100. PIECTRL Register Address Field Descriptions

| Bits | Field   | Value | Description                                                                                                                                                                                                                                                                              |
|------|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-1 | PIEVECT |       | These bits indicate the address within the PIE vector table from which the vector was fetched. The least significant bit of the address is ignored and only bits 1 to 15 of the address is shown. You can read the vector value to determine which interrupt generated the vector fetch. |
|      |         |       | <b>For Example:</b> If PIECTRL = 0x0D27 then the vector from address 0x0D26 (illegal operation) was fetched.                                                                                                                                                                             |
| 0    | ENPIE   |       | Enable vector fetching from PIE vector table.                                                                                                                                                                                                                                            |
|      |         |       | <b>Note:</b> The reset vector is never fetched from the PIE, even when it is enabled. This vector is always fetched from boot ROM.                                                                                                                                                       |
|      |         | 0     | If this bit is set to 0, the PIE block is disabled and vectors are fetched from the CPU vector table in boot ROM. All PIE block registers (PIEACK, PIEIFR, PIEIER) can be accessed even when the PIE block is disabled.                                                                  |
|      |         | 1     | When ENPIE is set to 1, all vectors, except for reset, are fetched from the PIE vector table. The reset vector is always fetched from the boot ROM.                                                                                                                                      |

#### Figure 1-76. PIE Interrupt Acknowledge Register (PIEACK) Register (Address 0xCE1)

| 15 12    | 11 0    |
|----------|---------|
| Reserved | PIEACK  |
| R-0      | R/W1C-0 |

LEGEND: R/W1C = Read/Write 1 to clear; R = Read only; -n = value after reset

#### Table 1-101. PIE Interrupt Acknowledge Register (PIEACK) Field Descriptions

| Bits  | Field    | Value           | Description                                                                                                                                                                                     |
|-------|----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Reserved |                 | Reserved                                                                                                                                                                                        |
| 11-0  | PIEACK   |                 | Each bit in PIEACK refers to a specific PIE group. Bit 0 refers to interrupts in PIE group 1 that are MUXed into INT1 up to Bit 11, which refers to PIE group 12 which is MUXed into CPU IN T12 |
|       |          | bit $x = 0$ (1) | If a bit reads as a 0, it indicates that the PIE can send an interrupt from the respective group to the CPU.                                                                                    |
|       |          |                 | Writes of 0 are ignored.                                                                                                                                                                        |
|       |          | bit $x = 1$     | Reading a 1 indicates if an interrupt from the respective group has been sent to the CPU and all other interrupts from the group are currently blocked.                                         |
|       |          |                 | Writing a 1 to the respective interrupt bit clears the bit and enables the PIE block to drive a pulse into the CPU interrupt input if an interrupt is pending for that group.                   |

(1) bit x = PIEACK bit 0 - PIEACK bit 11. Bit 0 refers to CPU INT1 up to Bit 11, which refers to CPU INT12

#### 1.5.5.1 **PIE Interrupt Flag Registers**

There are twelve PIEIFR registers, one for each CPU interrupt used by the PIE module (INT1-INT12).

|        | Figu   | ire 1-77. PIEIF      | ·RX Register (                            | x = 1 to 12)                                                                                                                   |                                                                                                                                      |                                                                                                                                                                                  |
|--------|--------|----------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |        |                      |                                           |                                                                                                                                |                                                                                                                                      | 8                                                                                                                                                                                |
|        |        | Res                  | erved                                     |                                                                                                                                |                                                                                                                                      |                                                                                                                                                                                  |
|        |        | F                    | R-0                                       |                                                                                                                                |                                                                                                                                      |                                                                                                                                                                                  |
| 6      | 5      | 4                    | 3                                         | 2                                                                                                                              | 1                                                                                                                                    | 0                                                                                                                                                                                |
| INTx.7 | INTx.6 | INTx.5               | INTx.4                                    | INTx.3                                                                                                                         | INTx.2                                                                                                                               | INTx.1                                                                                                                                                                           |
| R/W-0  | R/W-0  | R/W-0                | R/W-0                                     | R/W-0                                                                                                                          | R/W-0                                                                                                                                | R/W-0                                                                                                                                                                            |
|        | INTx.7 | 6 5<br>INTx.7 INTx.6 | Res<br>F<br>6 5 4<br>INTx.7 INTx.6 INTx.5 | Reserved           R-0           6         5         4         3           INTx.7         INTx.6         INTx.5         INTx.4 | R-0           6         5         4         3         2           INTx.7         INTx.6         INTx.5         INTx.4         INTx.3 | Reserved           R-0           6         5         4         3         2         1           INTx.7         INTx.6         INTx.5         INTx.4         INTx.3         INTx.2 |

## Eiguro 1-77 DIEIEPy Pagistor (y = 1 to 12)

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 1-102. PIEIFRx Register Field Descriptions

| Bits | Field    | Description                                                                                                                                                                                                                          |
|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved | Reserved                                                                                                                                                                                                                             |
| 7    | INTx.8   | These register bits indicate whether an interrupt is currently active. They behave very much like the CPU                                                                                                                            |
| 6    | INTx.7   | interrupt flag register. When an interrupt is active, the respective register bit is set. The bit is cleared when the interrupt is serviced or by writing a 0 to the register bit. This register can also be read to determine which |
| 5    | INTx.6   | interrupts are active or pending. $x = 1$ to 12. INTx means CPU INT1 to INT12                                                                                                                                                        |
| 4    | INTx.5   | The PIEIFR register bit is cleared during the interrupt vector fetch portion of the interrupt processing.                                                                                                                            |
| 3    | INTx.4   | Hardware has priority over CPU accesses to the PIEIFR registers.                                                                                                                                                                     |
| 2    | INTx.3   |                                                                                                                                                                                                                                      |
| 1    | INTx.2   |                                                                                                                                                                                                                                      |
| 0    | INTx.1   |                                                                                                                                                                                                                                      |

**NOTE:** Never clear a PIEIFR bit. An interrupt may be lost during the read-modify-write operation. See Section Section 1.5.3.1 for a method to clear flagged interrupts.

## 1.5.5.2 PIE Interrupt Enable Registers

There are twelve PIEIER registers, one for each CPU interrupt used by the PIE module (INT1-INT12).

## Figure 1-78. PIEIERx Register (x = 1 to 12)

|        |        |               |                                      |                                                                                               |                                                                                                                                      | 8                                                                                                                                                             |
|--------|--------|---------------|--------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |        | Reserve       | d                                    |                                                                                               |                                                                                                                                      |                                                                                                                                                               |
|        |        | R-0           |                                      |                                                                                               |                                                                                                                                      |                                                                                                                                                               |
| 6      | 5      | 4             | 3                                    | 2                                                                                             | 1                                                                                                                                    | 0                                                                                                                                                             |
| INTx.7 | INTx.6 | INTx.5        | INTx.4                               | INTx.3                                                                                        | INTx.2                                                                                                                               | INTx.1                                                                                                                                                        |
| R/W-0  | R/W-0  | R/W-0         | R/W-0                                | R/W-0                                                                                         | R/W-0                                                                                                                                | R/W-0                                                                                                                                                         |
|        | INTx.7 | INTx.7 INTx.6 | R-0<br>6 5 4<br>INTx.7 INTx.6 INTx.5 | 6         5         4         3           INTx.7         INTx.6         INTx.5         INTx.4 | R-0           6         5         4         3         2           INTx.7         INTx.6         INTx.5         INTx.4         INTx.3 | R-0           6         5         4         3         2         1           INTx.7         INTx.6         INTx.5         INTx.4         INTx.3         INTx.2 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



Peripheral Interrupt Expansion (PIE)

www.ti.com

#### Table 1-103. PIEIERx Register (x = 1 to 12) Field Descriptions

| Bits | Field    | Description                                                                                                                                                                                  |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved | Reserved                                                                                                                                                                                     |
| 7    | INTx.8   | These register bits individually enable an interrupt within a group and behave very much like the core interrupt                                                                             |
| 6    | INTx.7   | enable register. Setting a bit to 1 enables the servicing of the respective interrupt. Setting a bit to 0 disables the servicing of the interrupt. x = 1 to 12. INTx means CPU INT1 to INT12 |
| 5    | INTx.6   |                                                                                                                                                                                              |
| 4    | INTx.5   |                                                                                                                                                                                              |
| 3    | INTx.4   |                                                                                                                                                                                              |
| 2    | INTx.3   |                                                                                                                                                                                              |
| 1    | INTx.2   |                                                                                                                                                                                              |
| 0    | INTx.1   |                                                                                                                                                                                              |

**NOTE:** Care must be taken when clearing PIEIER bits during normal operation. See Section Section 1.5.3.2 for the proper procedure for handling these bits.

### 1.5.5.3 CPU Interrupt Flag Register (IFR)

The CPU interrupt flag register (IFR), is a 16-bit, CPU register and is used to identify and clear pending interrupts. The IFR contains flag bits for all the maskable interrupts at the CPU level (INT1-INT14, DLOGINT and RTOSINT). When the PIE is enabled, the PIE module multiplexes interrupt sources for INT1-INT12.

When a maskable interrupt is requested, the flag bit in the corresponding peripheral control register is set to 1. If the corresponding mask bit is also 1, the interrupt request is sent to the CPU, setting the corresponding flag in the IFR. This indicates that the interrupt is pending or waiting for acknowledgment.

To identify pending interrupts, use the PUSH IFR instruction and then test the value on the stack. Use the OR IFR instruction to set IFR bits and use the AND IFR instruction to manually clear pending interrupts. All pending interrupts are cleared with the AND IFR #0 instruction or by a hardware reset.

The following events also clear an IFR flag:

- The CPU acknowledges the interrupt.
- The 28x device is reset.

#### NOTE:

- 1. To clear a CPU IFR bit, you must write a zero to it, not a one.
- 2. When a maskable interrupt is acknowledged, only the IFR bit is cleared automatically. The flag bit in the corresponding peripheral control register is not cleared. If an application requires that the control register flag be cleared, the bit must be cleared by software.
- 3. When an interrupt is requested by an INTR instruction and the corresponding IFR bit is set, the CPU does not clear the bit automatically. If an application requires that the IFR bit be cleared, the bit must be cleared by software.
- 4. IMR and IFR registers pertain to core-level interrupts. All peripherals have their own interrupt mask and flag bits in their respective control/configuration registers. Note that several peripheral interrupts are grouped under one core-level interrupt.

| Figure 1-79. Interrupt Flag Register (IFR) — CPU Register |         |       |       |       |       |       |       |
|-----------------------------------------------------------|---------|-------|-------|-------|-------|-------|-------|
| 15                                                        | 14      | 13    | 12    | 11    | 10    | 9     | 8     |
| RTOSINT                                                   | DLOGINT | INT14 | INT13 | INT12 | INT11 | INT10 | INT9  |
| R/W-0                                                     | R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| 7                                                         | 6       | 5     | 4     | 3     | 2     | 1     | 0     |
| INT8                                                      | INT7    | INT6  | INT5  | INT4  | INT3  | INT2  | INT1  |
| R/W-0                                                     | R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-104. Interrupt Flag Register (IFR) — CPU Register Field Descriptions

| Bits | Field      | Value | Description                                                                                                       |
|------|------------|-------|-------------------------------------------------------------------------------------------------------------------|
| 15   | 15 RTOSINT |       | Real-time operating system flag. RTOSINT is the flag for RTOS interrupts.                                         |
|      |            | 0     | No RTOS interrupt is pending                                                                                      |
|      |            | 1     | At least one RTOS interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request    |
| 14   | DLOGINT    |       | Data logging interrupt fag. DLOGINT is the flag for data logging interrupts.                                      |
|      |            | 0     | No DLOGINT is pending                                                                                             |
|      |            | 1     | At least one DLOGINT interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request |
| 13   | INT14      |       | Interrupt 14 flag. INT14 is the flag for interrupts connected to CPU interrupt level INT14.                       |
|      |            | 0     | No INT14 interrupt is pending                                                                                     |
|      |            | 1     | At least one INT14 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request   |
| 12   | INT13      |       | Interrupt 13 flag. INT13 is the flag for interrupts connected to CPU interrupt level INT13I.                      |
|      |            | 0     | No INT13 interrupt is pending                                                                                     |
|      |            | 1     | At least one INT13 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request   |
| 11   | INT12      |       | Interrupt 12 flag. INT12 is the flag for interrupts connected to CPU interrupt level INT12.                       |
|      |            | 0     | No INT12 interrupt is pending                                                                                     |
|      |            | 1     | At least one INT12 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request   |
| 10   | INT11      |       | Interrupt 11 flag. INT11 is the flag for interrupts connected to CPU interrupt level INT11.                       |
|      |            | 0     | No INT11 interrupt is pending                                                                                     |
|      |            | 1     | At least one INT11 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request   |
| 9    | INT10      |       | Interrupt 10 flag. INT10 is the flag for interrupts connected to CPU interrupt level INT10.                       |
|      |            | 0     | No INT10 interrupt is pending                                                                                     |
|      |            | 1     | At least one INT6 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request    |
| 8    | INT9       |       | Interrupt 9 flag. INT9 is the flag for interrupts connected to CPU interrupt level INT6.                          |
|      |            | 0     | No INT9 interrupt is pending                                                                                      |
|      |            | 1     | At least one INT9 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request    |
| 7    | INT8       |       | Interrupt 8 flag. INT8 is the flag for interrupts connected to CPU interrupt level INT6.                          |
|      |            | 0     | No INT8 interrupt is pending                                                                                      |
|      |            | 1     | At least one INT8 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request    |
| 6    | INT7       |       | Interrupt 7 flag. INT7 is the flag for interrupts connected to CPU interrupt level INT7.                          |
|      |            | 0     | No INT7 interrupt is pending                                                                                      |
|      |            | 1     | At least one INT7 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request    |

#### Table 1-104. Interrupt Flag Register (IFR) — CPU Register Field Descriptions (continued)

| Bits | Field | Value | Description                                                                                                    |
|------|-------|-------|----------------------------------------------------------------------------------------------------------------|
| 5    | INT6  |       | Interrupt 6 flag. INT6 is the flag for interrupts connected to CPU interrupt level INT6.                       |
|      |       | 0     | No INT6 interrupt is pending                                                                                   |
|      |       | 1     | At least one INT6 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request |
| 4    | INT5  |       | Interrupt 5 flag. INT5 is the flag for interrupts connected to CPU interrupt level INT5.                       |
|      |       | 0     | No INT5 interrupt is pending                                                                                   |
|      |       | 1     | At least one INT5 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request |
| 3    | INT4  |       | Interrupt 4 flag. INT4 is the flag for interrupts connected to CPU interrupt level INT4.                       |
|      |       | 0     | No INT4 interrupt is pending                                                                                   |
|      |       | 1     | At least one INT4 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request |
| 2    | INT3  |       | Interrupt 3 flag. INT3 is the flag for interrupts connected to CPU interrupt level INT3.                       |
|      |       | 0     | No INT3 interrupt is pending                                                                                   |
|      |       | 1     | At least one INT3 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request |
| 1    | INT2  |       | Interrupt 2 flag. INT2 is the flag for interrupts connected to CPU interrupt level INT2.                       |
|      |       | 0     | No INT2 interrupt is pending                                                                                   |
|      |       | 1     | At least one INT2 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request |
| 0    | INT1  |       | Interrupt 1 flag. INT1 is the flag for interrupts connected to CPU interrupt level INT1.                       |
|      |       | 0     | No INT1 interrupt is pending                                                                                   |
|      |       | 1     | At least one INT1 interrupt is pending. Write a 0 to this bit to clear it to 0 and clear the interrupt request |

## 1.5.5.4 Interrupt Enable Register (IER) and Debug Interrupt Enable Register (DBGIER)

The IER is a 16-bit CPU register. The IER contains enable bits for all the maskable CPU interrupt levels (INT1-INT14, RTOSINT and DLOGINT). Neither NMI nor XRS is included in the IER; thus, IER has no effect on these interrupts.

You can read the IER to identify enabled or disabled interrupt levels, and you can write to the IER to enable or disable interrupt levels. To enable an interrupt level, set its corresponding IER bit to one using the OR IER instruction. To disable an interrupt level, set its corresponding IER bit to zero using the AND IER instruction. When an interrupt is disabled, it is not acknowledged, regardless of the value of the INTM bit. When an interrupt is enabled, it is acknowledged if the corresponding IFR bit is one and the INTM bit is zero.

When using the OR IER and AND IER instructions to modify IER bits make sure they do not modify the state of bit 15 (RTOSINT) unless a real-time operating system is present.

When a hardware interrupt is serviced or an INTR instruction is executed, the corresponding IER bit is cleared automatically. When an interrupt is requested by the TRAP instruction the IER bit is not cleared automatically. In the case of the TRAP instruction if the bit needs to be cleared it must be done by the interrupt service routine.

At reset, all the IER bits are cleared to 0, disabling all maskable CPU level interrupts.

The IER register is shown in Figure 1-80, and descriptions of the bits follow the figure.

#### Peripheral Interrupt Expansion (PIE)

| Figure 1-80. Interrupt Enable Register (IER) — CPU Register |         |       |       |       |       |       |       |
|-------------------------------------------------------------|---------|-------|-------|-------|-------|-------|-------|
| 15                                                          | 14      | 13    | 12    | 11    | 10    | 9     | 8     |
| RTOSINT                                                     | DLOGINT | INT14 | INT13 | INT12 | INT11 | INT10 | INT9  |
| R/W-0                                                       | R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| 7                                                           | 6       | 5     | 4     | 3     | 2     | 1     | 0     |
| INT8                                                        | INT7    | INT6  | INT5  | INT4  | INT3  | INT2  | INT1  |
| R/W-0                                                       | R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-105. Interrupt Enable Register (IER) — CPU Register Field Descriptions

| Bits | Field   | Value | Description                                                                                      |
|------|---------|-------|--------------------------------------------------------------------------------------------------|
| 15   | RTOSINT |       | Real-time operating system interrupt enable. RTOSINT enables or disables the CPU RTOS interrupt. |
|      |         | 0     | Level INT6 is disabled                                                                           |
|      |         | 1     | Level INT6 is enabled                                                                            |
| 14   | DLOGINT |       | Data logging interrupt enable. DLOGINT enables or disables the CPU data logging interrupt.       |
|      |         | 0     | Level INT6 is disabled                                                                           |
|      |         | 1     | Level INT6 is enabled                                                                            |
| 13   | INT14   |       | Interrupt 14 enable. INT14 enables or disables CPU interrupt level INT14.                        |
|      |         | 0     | Level INT14 is disabled                                                                          |
|      |         | 1     | Level INT14 is enabled                                                                           |
| 12   | INT13   |       | Interrupt 13 enable. INT13 enables or disables CPU interrupt level INT13.                        |
|      |         | 0     | Level INT13 is disabled                                                                          |
|      |         | 1     | Level INT13 is enabled                                                                           |
| 11   | INT12   |       | Interrupt 12 enable. INT12 enables or disables CPU interrupt level INT12.                        |
|      |         | 0     | Level INT12 is disabled                                                                          |
|      |         | 1     | Level INT12 is enabled                                                                           |
| 10   | INT11   |       | Interrupt 11 enable. INT11 enables or disables CPU interrupt level INT11.                        |
|      |         | 0     | Level INT11 is disabled                                                                          |
|      |         | 1     | Level INT11 is enabled                                                                           |
| 9    | INT10   |       | Interrupt 10 enable. INT10 enables or disables CPU interrupt level INT10.                        |
|      |         | 0     | Level INT10 is disabled                                                                          |
|      |         | 1     | Level INT10 is enabled                                                                           |
| 8    | INT9    |       | Interrupt 9 enable. INT9 enables or disables CPU interrupt level INT9.                           |
|      |         | 0     | Level INT9 is disabled                                                                           |
|      |         | 1     | Level INT9 is enabled                                                                            |
| 7    | INT8    |       | Interrupt 8 enable. INT8 enables or disables CPU interrupt level INT8.                           |
|      |         | 0     | Level INT8 is disabled                                                                           |
|      |         | 1     | Level INT8 is enabled                                                                            |
| 6    | INT7    |       | Interrupt 7 enable. INT7 enables or disables CPU interrupt level INT7.                           |
|      |         | 0     | Level INT7 is disabled                                                                           |
|      |         | 1     | Level INT7 is enabled                                                                            |
| 5    | INT6    |       | Interrupt 6 enable. INT6 enables or disables CPU interrupt level INT6.                           |
|      |         | 0     | Level INT6 is disabled                                                                           |
|      |         | 1     | Level INT6 is enabled                                                                            |
| 4    | INT5    |       | Interrupt 5 enable.INT5 enables or disables CPU interrupt level INT5.                            |
|      |         | 0     | Level INT5 is disabled                                                                           |
|      |         | 1     | Level INT5 is enabled                                                                            |

| Bits                                                       | Field | Value | Description                                                           |
|------------------------------------------------------------|-------|-------|-----------------------------------------------------------------------|
| 3                                                          | INT4  |       | Interrupt 4 enable.INT4 enables or disables CPU interrupt level INT4. |
|                                                            |       | 0     | Level INT4 is disabled                                                |
|                                                            |       | 1     | Level INT4 is enabled                                                 |
| 2                                                          | INT3  |       | Interrupt 3 enable.INT3 enables or disables CPU interrupt level INT3. |
|                                                            |       | 0     | Level INT3 is disabled                                                |
|                                                            |       | 1     | Level INT3 is enabled                                                 |
| 1                                                          | INT2  |       | Interrupt 2 enable.INT2 enables or disables CPU interrupt level INT2. |
|                                                            |       | 0     | Level INT2 is disabled                                                |
|                                                            |       | 1     | Level INT2 is enabled                                                 |
| 0 INT1 Interrupt 1 enable.INT1 enables or disables CPU int |       |       | Interrupt 1 enable.INT1 enables or disables CPU interrupt level INT1. |
|                                                            |       | 0     | Level INT1 is disabled                                                |
|                                                            |       | 1     | Level INT1 is enabled                                                 |

Table 1-105. Interrupt Enable Register (IER) — CPU Register Field Descriptions (continued)

The Debug Interrupt Enable Register (DBGIER) is used only when the CPU is halted in real-time emulation mode. An interrupt enabled in the DBGIER is defined as a time-critical interrupt. When the CPU is halted in real-time mode, the only interrupts that are serviced are time-critical interrupts that are also enabled in the IER. If the CPU is running in real-time emulation mode, the standard interrupt-handling process is used and the DBGIER is ignored.

As with the IER, you can read the DBGIER to identify enabled or disabled interrupts and write to the DBGIER to enable or disable interrupts. To enable an interrupt, set its corresponding bit to 1. To disable an interrupt, set its corresponding bit to 0. Use the PUSH DBGIER instruction to read from the DBGIER and POP DBGIER to write to the DBGIER register. At reset, all the DBGIER bits are set to 0.

|         | 0       | U     | •     | U 1   | · /   | 0     |       |
|---------|---------|-------|-------|-------|-------|-------|-------|
| 15      | 14      | 13    | 12    | 11    | 10    | 9     | 8     |
| RTOSINT | DLOGINT | INT14 | INT13 | INT12 | INT11 | INT10 | INT9  |
| R/W-0   | R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| 7       | 6       | 5     | 4     | 3     | 2     | 1     | 0     |
| INT8    | INT7    | INT6  | INT5  | INT4  | INT3  | INT2  | INT1  |
| R/W-0   | R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|         |         |       |       |       |       |       |       |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-106. Debug Interrupt Enable Register (DBGIER) — CPU Register Field Descriptions

| Bits | Field   | Value | Description                                                                                      |
|------|---------|-------|--------------------------------------------------------------------------------------------------|
| 15   | RTOSINT |       | Real-time operating system interrupt enable. RTOSINT enables or disables the CPU RTOS interrupt. |
|      |         | 0     | Level INT6 is disabled                                                                           |
|      |         | 1     | Level INT6 is enabled                                                                            |
| 14   | DLOGINT |       | Data logging interrupt enable. DLOGINT enables or disables the CPU data logging interrupt        |
|      |         | 0     | Level INT6 is disabled                                                                           |
|      |         | 1     | Level INT6 is enabled                                                                            |
| 13   | INT14   |       | Interrupt 14 enable. INT14 enables or disables CPU interrupt level INT14                         |
|      |         | 0     | Level INT14 is disabled                                                                          |
|      |         | 1     | Level INT14 is enabled                                                                           |
| 12   | INT13   |       | Interrupt 13 enable. INT13 enables or disables CPU interrupt level INT13.                        |
|      |         | 0     | Level INT13 is disabled                                                                          |
|      |         | 1     | Level INT13 is enabled                                                                           |

# Table 1-106. Debug Interrupt Enable Register (DBGIER) — CPU Register Field Descriptions (continued)

| Bits | Field | Value | Description                                                               |
|------|-------|-------|---------------------------------------------------------------------------|
| 11   | INT12 |       | Interrupt 12 enable. INT12 enables or disables CPU interrupt level INT12. |
|      |       | 0     | Level INT12 is disabled                                                   |
|      |       | 1     | Level INT12 is enabled                                                    |
| 10   | INT11 |       | Interrupt 11 enable. INT11 enables or disables CPU interrupt level INT11. |
|      |       | 0     | Level INT11 is disabled                                                   |
|      |       | 1     | Level INT11 is enabled                                                    |
| 9    | INT10 |       | Interrupt 10 enable. INT10 enables or disables CPU interrupt level INT10. |
|      |       | 0     | Level INT10 is disabled                                                   |
|      |       | 1     | Level INT10 is enabled                                                    |
| 8    | INT9  |       | Interrupt 9 enable. INT9 enables or disables CPU interrupt level INT9.    |
|      |       | 0     | Level INT9 is disabled                                                    |
|      |       | 1     | Level INT9 is enabled                                                     |
| 7    | INT8  |       | Interrupt 8 enable. INT8 enables or disables CPU interrupt level INT8.    |
|      |       | 0     | Level INT8 is disabled                                                    |
|      |       | 1     | Level INT8 is enabled                                                     |
| 6    | INT7  |       | Interrupt 7 enable. INT7 enables or disables CPU interrupt level INT77.   |
|      |       | 0     | Level INT7 is disabled                                                    |
|      |       | 1     | Level INT7 is enabled                                                     |
| 5    | INT6  |       | Interrupt 6 enable. INT6 enables or disables CPU interrupt level INT6.    |
|      |       | 0     | Level INT6 is disabled                                                    |
|      |       | 1     | Level INT6 is enabled                                                     |
| 4    | INT5  |       | Interrupt 5 enable.INT5 enables or disables CPU interrupt level INT5.     |
|      |       | 0     | Level INT5 is disabled                                                    |
|      |       | 1     | Level INT5 is enabled                                                     |
| 3    | INT4  |       | Interrupt 4 enable.INT4 enables or disables CPU interrupt level INT4.     |
|      |       | 0     | Level INT4 is disabled                                                    |
|      |       | 1     | Level INT4 is enabled                                                     |
| 2    | INT3  |       | Interrupt 3 enable.INT3 enables or disables CPU interrupt level INT3.     |
|      |       | 0     | Level INT3 is disabled                                                    |
|      |       | 1     | Level INT3 is enabled                                                     |
| 1    | INT2  |       | Interrupt 2 enable.INT2 enables or disables CPU interrupt level INT2.     |
|      |       | 0     | Level INT2 is disabled                                                    |
|      |       | 1     | Level INT2 is enabled                                                     |
| 0    | INT1  |       | Interrupt 1 enable.INT1 enables or disables CPU interrupt level INT1.     |
|      |       | 0     | Level INT1 is disabled                                                    |
|      |       | 1     | Level INT1 is enabled                                                     |

#### 1.5.6 External Interrupt Control Registers

Three external interrupts, XINT1 –XINT3 are supported. Each of these external interrupts can be selected for negative or positive edge triggered and can also be enabled or disabled. The masked interrupts also contain a 16-bit free running up counter that is reset to zero when a valid interrupt edge is detected. This counter can be used to accurately time stamp the interrupt.

| Name     | Address Range             | Size (x16)                     | Description                  |
|----------|---------------------------|--------------------------------|------------------------------|
| XINT1CR  | TICR 0x0000 7070          |                                | XINT1 configuration register |
| XINT2CR  | 0x0000 7071               | 1 XINT2 configuration register |                              |
| XINT3CR  | 0x0000 7072               | 1                              | XINT3 configuration register |
| reserved | 0x0000 7073 - 0x0000 7077 | 5                              |                              |
| XINT1CTR | 0x0000 7078               | 1 XINT1 counter register       |                              |
| XINT2CTR | 0x0000 7079               | 1 XINT2 counter register       |                              |
| XINT3CTR | 0x0000 707A               | 1                              | XINT3 counter register       |
| reserved | 0x0000 707B - 0x0000 707E | 5                              |                              |

XINT1CR through XINT3CR are identical except for the interrupt number; therefore, Figure 1-82 and Table 1-108 represent registers for external interrupts 1 through 3 as XINT*n*CR where n = the interrupt number.

| Figure 1-82. | External | Interrupt n Control | Register | (XINTnCR) |
|--------------|----------|---------------------|----------|-----------|
| J            |          |                     |          |           |

| 15       | 4   | 3    | 2    | 1        | 0      |
|----------|-----|------|------|----------|--------|
| Reserved |     | Pola | rity | Reserved | Enable |
| R-0      | R/W | /-0  | R-0  | R/W-0    |        |
|          |     |      |      |          |        |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-108. External Interrupt n Control Register (XINTnCR) Field Descriptions

| Bits | Field    | Value | Description                                                                                                                    |
|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 15-4 | Reserved |       | Reads return zero; writes have no effect.                                                                                      |
| 3-2  | Polarity |       | This read/write bit determines whether interrupts are generated on the rising edge or the falling edge of a signal on the pin. |
|      |          | 00    | Interrupt generated on a falling edge (high-to-low transition)                                                                 |
|      |          | 01    | Interrupt generated on a rising edge (low-to-high transition)                                                                  |
|      |          | 10    | Interrupt is generated on a falling edge (high-to-low transition)                                                              |
|      |          | 11    | Interrupt generated on both a falling edge and a rising edge (high-to-low and low-to-high transition)                          |
| 1    | Reserved |       | Reads return zero; writes have no effect                                                                                       |
| 0    | Enable   |       | This read/write bit enables or disables external interrupt XINTn.                                                              |
|      |          | 0     | Disable interrupt                                                                                                              |
|      |          | 1     | Enable interrupt                                                                                                               |

For XINT1/XINT2/XINT3, there is also a 16-bit counter that is reset to 0x000 whenever an interrupt edge is detected. These counters can be used to accurately time stamp an occurrence of the interrupt. XINT1CTR through XINT3CTR are identical except for the interrupt number; therefore, Figure 1-83 and Table 1-109 represent registers for the external interrupts as XINTnCTR, where n = the interrupt number.



## Figure 1-83. External Interrupt n Counter (XINTnCTR) (Address 7078h)

15

0

#### INTCTR[15-8]

R-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-109. External Interrupt n Counter (XINTnCTR) Field Descriptions

| Bits | Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | INTCTR | This is a free running 16-bit up-counter that is clocked at the SYSCLKOUT rate. The counter value is reset to 0x0000 when a valid interrupt edge is detected and then continues counting until the next valid interrupt edge is detected. When the interrupt is disabled, the counter stops. The counter is a free-running counter and wraps around to zero when the max value is reached. The counter is a read only register and can only be reset to zero by a valid interrupt edge or by reset. |



#### 1.6 VREG/BOR/POR

Although the core and I/O circuitry operate on two different voltages, these devices have an on-chip voltage regulator (VREG) to generate the  $V_{DD}$  voltage from the  $V_{DDIO}$  supply. This eliminates the cost and area of a second external regulator on an application board. Additionally, internal power-on reset (POR) and brown-out reset (BOR) circuits monitor both the  $V_{DD}$  and  $V_{DDIO}$  rails during power-up and run mode.

#### 1.6.1 On-chip Voltage Regulator (VREG)

An on-chip voltage regulator facilitates the powering of the device without adding the cost or board space of a second external regulator. This linear regulator generates the core  $V_{DD}$  voltage from the  $V_{DDIO}$  supply. Therefore, although capacitors are required on each  $V_{DD}$  pin to stabilize the generated voltage, power need not be supplied to these pins to operate the device. Conversely, the VREG can be bypassed or overdriven, should power or redundancy be the primary concern of the application.

#### 1.6.1.1 Using the On-chip VREG

To utilize the on-chip VREG, the VREGENZ pin should be pulled low and the appropriate recommended operating voltage should be supplied to the V<sub>DDIO</sub> and V<sub>DDA</sub> pins. In this case, the V<sub>DD</sub> voltage needed by the core logic will be generated by the VREG. Each V<sub>DD</sub> pin requires on the order of 1.2  $\mu$ F capacitance for proper regulation of the VREG. These capacitors should be located as close as possible to the device pins. See the TMS320F28055, TMS320F28054, TMS320F28053, TMS320F28052, TMS320F28051, TMS320F28050 Piccolo Microcontrollers Data Manual (literature number <u>SPRS797</u>) for the acceptable range of capacitance.

#### 1.6.1.2 Bypassing the On-chip VREG

To conserve power, it is also possible to bypass the on-chip VREG and supply the core logic voltage to the V<sub>DD</sub> pins with a more efficient external regulator. To enable this option, the VREGENZ pin must be pulled high. See the TMS320F28055, TMS320F28054, TMS320F28053, TMS320F28052, TMS320F28051, TMS320F28050 Piccolo Microcontrollers Data Manual (literature number <u>SPRS797</u>) for the acceptable range of voltage that must be supplied to the V<sub>DD</sub> pins.

# 1.6.2 On-chip Power-On Reset (POR) and Brown-Out Reset (BOR) Circuit

The purpose of the power-on reset (POR) is to create a clean reset throughout the device during the entire power-up procedure. The trip point is a looser, lower trip point than the brown-out reset (BOR), which watches for dips in the  $V_{DD}$  or  $V_{DDIO}$  rail during device operation. The POR function is present on both  $V_{DD}$  and  $V_{DDIO}$  rails at all times. After initial device power-up, the BOR function is present on  $V_{DDIO}$  at all times, and on  $V_{DD}$  when the internal VREG is enabled (VREGENZ pin is pulled low). Both functions pull the XRS pin low when one of the voltages is below their respective trip point. Additionally, when monitoring the  $V_{DD}$  rail, the BOR pulls XRS low when  $V_{DD}$  is above its overvoltage trip point. See the device data manual for the various trip points as well as the delay time from the removal of the fault condition to the release of the XRS pin.

A bit is provided in the BORCFG register (address 0x985) to disable both the VDD and VDDIO BOR functions. The default state of this bit has the BOR enabled. When the BOR functions are disabled, the POR functions will remain enabled. See Figure 1-84 for a description of the BORCFG register. The BORCFG register is only reset by the XRS signal.

## Figure 1-84. BOR Configuration (BORCFG) Register

| 15       | 3 | 2        | 1        | 0      |
|----------|---|----------|----------|--------|
| Reserved |   | Reserved | Reserved | BORENZ |
| R-0      |   | R-1      | R/W-0    | R/W-0  |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

## Table 1-110. BOR Configuration (BORCFG) Field Descriptions

| Bits | Field    | Value | Description                                               |  |
|------|----------|-------|-----------------------------------------------------------|--|
| 15-3 | Reserved |       | Any writes to these bit(s) must always have a value of 0. |  |
| 2    | Reserved | 1     | Reads always return a one. Writes have no effect.         |  |
| 1    | Reserved |       | Any writes to these bit(s) must always have a value of 0. |  |
| 0    | BORENZ   |       | BOR enable active low bit.                                |  |
|      |          | 0     | BOR functions are enabled.                                |  |
|      |          | 1     | BOR functions are disabled.                               |  |

# 1.7 Dual Code Security Module (DCSM)

The dual code security module (DCSM) is a security feature incorporated in this device. It prevents access and visibility to on-chip secure memories (and other secure resources) to unauthorized persons — that is, it prevents duplication/reverse engineering of proprietary code. The word secure means accesses to on-chip secure memories and other secure resources are protected. The word unsecure means accesses to on-chip securable memory and other securable resources are not protected — that is, the contents of the memory could be read by any means; for example, through a debugging tool such as Code Composer Studio<sup>™</sup>(CCS).

# 1.7.1 Functional Description

The security module restricts the CPU access to on-chip secure memory and resource without interrupting or stalling CPU execution. When a read occurs to a secure memory location, the read returns a zero value and CPU execution continues with the next instruction. This, in effect, blocks read and write access to secure memories through the JTAG port or external peripherals. Security is defined with respect to the access of on-chip secure memories and resources and prevents unauthorized copying of proprietary code or data.

The code security mechanism present in this device offers dual zone security: Zone 1 and Zone 2. Hereafter, these two zones will be referred to as Z1 and Z2 in this document. The security mechanism for both the zones are identical. Each zone has its own dedicated secure resource and allocated secure resource. Following are different secure resources available on this device.

- **OTP:** Each zone has its own dedicated secure OTP. This contains the security configurations for each individual zone.
- CLA: The CLA is a secure resource which is always dedicated to Z1. This means the CLA



configuration can be performed by code running from Z1 only. The CLA message RAMs also belong to Z1.

- **RAM:** All Lx RAMs can be secure RAM on this device. These RAMs can be allocated to either zone by configuring the respective GRABRAM location in USER OTP.
- Flash Sectors: Flash sectors can be secure on this device. Each flash sector can be allocated to either zone by configuring the GRABSECT location in USER OTP.
- Secure ROM: This device also has secure ROM and is reserved for TI use only.

Table 1-111 shows the status of a RAM block based on the configuration in the GRABRAM register.

| Z1_GRABRAMR[GRAB-Lx] | Z2_GRABRAMR[GRAB-Lx] | Ownership              |
|----------------------|----------------------|------------------------|
| 0                    | XX                   | Lx RAM is inaccessible |
| XX                   | 0                    | Lx RAM is inaccessible |
| 01 or 10             | 01 or 10             | Lx RAM is inaccessible |
| 01 or 10             | 11                   | Lx RAM belongs to Z1   |
| 11                   | 01 or 10             | Lx RAM belongs to Z2   |
| 11                   | 11                   | Lx RAM is non-secure   |

#### Table 1-111. RAM Status

Similarly, flash sectors get assigned to zones based on the bits in the GRABSECT registers.

Each zone is secured by its own passwords. The passwords for each zone are stored in a dedicated OTP address location based on the zone-specific link pointer (Z1\_LINKPOINTER or Z2\_LINKPOINTER). A zone can be unsecured by executing the password match flow (PMF), described in Section 1.7.6.

There are three types of accesses: data reads, JTAG access, and instruction fetches (calls/jumps/code executions/ISRs). Instruction fetches are never blocked. JTAG accesses are always blocked when a memory is secure. Data reads to a secure memory are always blocked unless the program is executing from a memory which belongs to the same zone. Data reads to unsecure memory are always allowed. Table 1-112 shows the levels of security.

| Access Type                     | Unsecured Zone | Secured Zone                                |                                                 |  |
|---------------------------------|----------------|---------------------------------------------|-------------------------------------------------|--|
|                                 |                | Code Executing Inside<br>of Respective Zone | Code Executing<br>Outside of Respective<br>Zone |  |
| Data Reads                      | Y              | Y                                           | Ν                                               |  |
| JTAG Access                     | Y              | N                                           | Ν                                               |  |
| Calls/Jumps/Instruction Fetches | Y              | Y                                           | Y                                               |  |

The following example shows one possible security configuration and the effects of the DCSM on the system:

| Memory | Assigned Zone | Status   |
|--------|---------------|----------|
| LO     | Z1            | Secure   |
| L1     | Z2            | Secure   |
| L2     | Z2            | Secure   |
| L3     | -             | Unsecure |

#### Case 1: Code is running from L3

- Can read from L0, L1, L2, L3
- JTAG can read from L3
- Can call/jump/interrupt to L0, L1, L2, L3

#### Case 2: Code is running from L2

TEXAS INSTRUMENTS

#### www.ti.com

- Can read from L1, L2, L3
- JTAG can read from L3
- Can call/jump/interrupt to L0, L1, L2, L3

#### Case 3: Code is running from L0

- Can read from L0, L3
- JTAG can read from L3
- Can call/jump/interrupt to L0, L1, L2, L3

If a zone is unsecured at any point, it can be accessed by all of the same items as L3 in the example above.

If the password locations of a zone have all 128 bits as 1, the zone is labeled unsecure. Since new flash devices have erased flash (all 1s), only a read of the password locations is required to bring any zone into unsecure mode. If the password locations of a zone have all 128 bits as 0s, the zone is secure, regardless of the contents of the CSMKEY registers (registers that are used to unsecure a zone). This means the zone cannot be unlocked using the PMF. The user should never use all 0s as a password or reset the device during an erase of the flash. Resetting the device during an erase routine can result in an all 0s or an unknown password. If a device is reset when the password locations are all 0s, the device cannot be unlocked by the PMF. A password of all 0s will severely limits the user's ability to debug secure code or reprogram the flash.

**Note**: If a device is reset while the password locations of a zone are all 0s or an unknown value, that zone will be permanently locked unless a method to change the link pointer from secure SARAM is embedded into the flash. Care must be taken when implementing this procedure to avoid introducing a security hole.

#### 1.7.1.1 Emulation Code Security Logic (ECSL)

In addition to the DCSM, the emulation code security logic (ECSL) has been implemented using a 64-bit password (part of the existing password) for each zone to prevent unauthorized users from stepping through secure code. A halt in secure code while the emulator is connected will trip the ECSL and break the emulation connection. To allow emulation of secure code while maintaining the DCSM protection against secure memory reads, the user must write the correct 64-bit password into the CSMKEY(0/1) registers, which matches the password value stored in the flash. This will disable the ECSL.

When initially debugging a device with the password locations in OTP programmed (secured), the emulator takes some time to take control of the CPU. During this time, the CPU will start running and may execute an instruction that performs an access to a protected ECSL area. If the CPU is halted when the program counter (PC) is pointing to a secure location, the ECSL will trip and cause the emulator connection to be cut.

There are two solutions to this problem:

- 1. Use the "wait boot mode" boot option. In this mode the core will be in a loop and continuously poll the boot mode select pins. You can then exit this mode once the emulator is connected by re-mapping the PC to another address or by changing the boot mode selection pin to the desired boot mode.
- 2. Program the lower 64-bits of the password to all 0s. The default CSMKEY is all 0s, so if the low 64-bits of the password are programmed to 0, the ECSL will be disabled automatically.

#### 1.7.1.2 CPU Secure Logic

CPU Secure Logic (CPUSL) on this device prevents hackers from reading the CPU register in the Code Composer Studio Registers Window while code is running through a secure zone. All accesses to the CPU registers when the PC points to a secure location are blocked by this logic. The only exception to this is a read access to the PC. It is highly recommended not to write into CPU registers in this case because proper code execution may be affected. If the DCSM is unlocked using the PMF, CPUSL logic is also disabled.



# 1.7.1.3 Execute-Only Protection

To achieve a higher level of security on secure flash sectors and RAM blocks which store critical user code (instruction opcodes), the Execute-Only Protection feature is provided on this device. When this feature is turned on for any secure flash sector or RAM block, data reads to those flash sectors are disallowed from any code (even from secure code). Execute-Only Protection for a flash sector and RAM block can be enabled by configuring the zone's (which has ownership of that sector/RAM block) EXEONLYSECT and EXEONLYRAM register, respectively. A method to copy code from EXEONLY flash to EXEONLY RAM is explained in Section 1.7.3.

#### 1.7.1.4 Link Pointer and Zone Select

For each of the two security zones on the device, a dedicated OTP block holds the configuration related to the zone's security. Following are the configurations which are programmed in these respective OTP blocks:

- Zx-LINKPOINTER
- Zx-OTPSECLOCK
- Zx-BOOTMODE
- Zx-EXEONLYRAM
- Zx-EXEONLYSECT
- Zx-GRABRAM
- Zx-GRABSECT
- Zx-CSMPASSWORD

Since OTP can not be erased, to provide flexibility for configuring some of the security settings like passwords, allocation of RAM/Flash sectors and their attributes multiple times by the user, the following configurations are placed in a Zone Select Block of each zone's OTP.

- Zx-EXEONLYRAM
- Zx-EXEONLYSECT
- Zx-GRABRAM
- Zx-GRABSECT
- Zx-CSMPASSWORD

The location of the Zone Select Block in OTP is decided based on the value of the 32-bit link pointer (Zx LINKPOINTER) programmed at the first location in the OTP of each zone. Since in OTP, a '1' can be flipped by the user to '0' but a '0' can not be flipped to a '1' (no erase operation for OTP), the most significant bit position in the link pointer which is programmed as '0' defines the valid base address for the Zone Select Block. Address locations for Zx-OTPSECLOCK and Zx-BOOTMODE in OTP are fixed. Figure 1-85 and Table 1-113 illustrate the storage and locations of the Zone Select Block.





Figure 1-85. Storage of Zone Select bits in OTP

#### Table 1-113. Location of Zone-Select Block Based on Link-Pointer

| Table 1-113. Location of Zone-Select Block Based on Link-Pointer |                         |                                  |  |  |  |  |  |
|------------------------------------------------------------------|-------------------------|----------------------------------|--|--|--|--|--|
| Zx-LINKPOINTER                                                   | Valid Zone Select Block | Addr Offset Of Zone Select Block |  |  |  |  |  |
| 32'bxx11111111111111111111111111111111111                        | Zone Select Block 0     | 0x10                             |  |  |  |  |  |
| 32'bxx11111111111111111111111111111111111                        | Zone Select Block 1     | 0x20                             |  |  |  |  |  |
| 32'bxx11111111111111111111111111111111111                        | Zone Select Block 2     | 0x30                             |  |  |  |  |  |
| 32'bxx11111111111111111111111111111111111                        | Zone Select Block 3     | 0x40                             |  |  |  |  |  |
| 32'bxx11111111111111111111111111111111111                        | Zone Select Block 4     | 0x50                             |  |  |  |  |  |
| 32'bxx11111111111111111111111111111111111                        | Zone Select Block 5     | 0x60                             |  |  |  |  |  |
| 32'bxx11111111111111111111111111111111111                        | Zone Select Block 6     | 0x70                             |  |  |  |  |  |
| 32'bxx11111111111111111111111111111111111                        | Zone Select Block 7     | 0x80                             |  |  |  |  |  |
| 32'bxx111111111111111111111111110x<br>xxxxxx                     | Zone Select Block 8     | 0x90                             |  |  |  |  |  |
| 32'bxx11111111111111111111110xx<br>xxxxxx                        | Zone Select Block 9     | 0xa0                             |  |  |  |  |  |
| 32'bxx1111111111111111111110xxx<br>xxxxxx                        | Zone Select Block 10    | 0xb0                             |  |  |  |  |  |
| 32'bxx111111111111111111110xxxx<br>xxxxxx                        | Zone Select Block 11    | 0xc0                             |  |  |  |  |  |
| 32'bxx11111111111111111110xxxxx<br>xxxxxx                        | Zone Select Block 12    | 0xd0                             |  |  |  |  |  |
| 32'bxx111111111111111110xxxxxx<br>xxxxxx                         | Zone Select Block 13    | 0xe0                             |  |  |  |  |  |
| 32'bxx11111111111111110xxxxxxx<br>xxxxxx                         | Zone Select Block 14    | 0xf0                             |  |  |  |  |  |
| 32'bxx1111111111111110xxxxxxx xx xxxxx                           | Zone Select Block 15    | 0x100                            |  |  |  |  |  |
| 32'bxx111111111111110xxxxxxxx xxxx                               | Zone Select Block 16    | 0x110                            |  |  |  |  |  |
| 32'bxx11111111111110xxxxxxxxx xxx                                | Zone Select Block 17    | 0x120                            |  |  |  |  |  |
| 32'bxx111111111110xxxxxxxxxx xxx                                 | Zone Select Block 18    | 0x130                            |  |  |  |  |  |
| 32'bxx11111111110xxxxxxxxxxx xxx xxx                             | Zone Select Block 19    | 0x140                            |  |  |  |  |  |
| 32'bxx1111111110xxxxxxxxxxxxxxxxxxxxxxxxx                        | Zone Select Block 20    | 0x150                            |  |  |  |  |  |
| 32'bxx111111110xxxxxxxxxxxxxxxx<br>xxxxx                         | Zone Select Block 21    | 0x160                            |  |  |  |  |  |
| 32'bxx111111110xxxxxxxxxxxxxxxxxxxxxxxxxxx                       | Zone Select Block 22    | 0x170                            |  |  |  |  |  |
| 32'bxx1111110xxxxxxxxxxxxxxxxxxxxxxxxxxxxx                       | Zone Select Block 23    | 0x180                            |  |  |  |  |  |
| 32'bxx1111110xxxxxxxxxxxxxxxxxxxxxxxxxxxxx                       | Zone Select Block 24    | 0x190                            |  |  |  |  |  |
| 32'bxx111110xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx                       | Zone Select Block 25    | 0x1a0                            |  |  |  |  |  |
| 32'bxx11110xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx                       | Zone Select Block 26    | 0x1b0                            |  |  |  |  |  |
| 32'bxx1110xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx                       | Zone Select Block 27    | 0x1c0                            |  |  |  |  |  |



| Zx-LINKPOINTER                             | Valid Zone Select Block | Addr Offset Of Zone Select Block |  |
|--------------------------------------------|-------------------------|----------------------------------|--|
| 32'bxx110xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | Zone Select Block 28    | 0x1d0                            |  |
| 32'bxx10xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | Zone Select Block 29    | 0x1e0                            |  |
| 32'bxx0xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx  | Zone Select Block 30    | 0x1f0                            |  |

 Table 1-113. Location of Zone-Select Block Based on Link-Pointer (continued)

# 1.7.2 Flash Erase/Program

On this device, flash sectors are secure resources. Flash sectors can be allocated to any zone based on the value programmed in the GRABSECT location in OTP. Each zone has its own passwords, and read/write accesses are not allowed to resources owned by Z1 from code running from memory allocated to Z2 and vice versa. Before programming any secure flash sector, the user must unlock the zone (using PMF) to which that particular sector belongs. The same is true for erasing any secure flash sector. Alternatively, the user does not have to unlock a zone if the code to erase/program that zone is running from RAM in the same zone.

This device has only one flash pump used for the erase and program operations of flash. A semaphore mechanism is provided to avoid the conflict between Zone 1 and Zone 2. A zone must grab this semaphore to successfully complete the erase/program operation on the flash sectors allocated to that zone. A zone can grab the semaphore by writing the appropriate value in the SEM field of the FLSEM register. Please see the register description for further details of this field.

# 1.7.3 Safe Copy Code

In some applications the user may want to copy the code from secure flash to secure RAM for better performance. To copy code from an EXEONLY flash sector to an EXEONLY RAM block, the user must use the "Safe Copy Code" library functions provided by TI. These functions perform the copy code operation in a highly secure environment and allow copying only in the following conditions:

- Secure RAM block and secure flash sectors belongs to same zone.
- Both secure RAM block and secure flash sectors have EXEONLY protection.

Please refer to the boot ROM section of the *ROM Code and Peripheral Booting* chapter for the further usage of these library functions.

**NOTE:** The user must disable all the interrupts before calling the safe copy code function. If there is a vector fetch during copy code operation, the CPU gets reset immediately.

# 1.7.4 DCSM Impact on Other On-Chip Resources

On this device, M0/M1 memories are not secure. To avoid any potential hacking when the device is in its default state (post reset), accesses (all types) to all memories (secure as well as non-secure, except boot ROM and OTP) are disabled until proper security initialization is completed. This means that just after reset none of the memory resources except boot ROM and OTP are accessible to the user. This process is automatically executed by the boot ROM and the default CCS GEL files provided by TI.

Following are the steps required after reset (any type of reset) to initialize the security on the device:

- Dummy read to address location of SECDC (0x3D7FFE ) in TI OTP.
- Dummy read to address location of Z1\_OTPSECLOCK in Z1 OTP.
- Dummy read to address location of Z1\_BOOTMODE in Z1 OTP.
- Dummy read to address location of Z1\_LINKPOINTER in Z1 OTP.
- Read to memory map register of Z1\_LINKPOINTER in DCSM module to calculate the address of zone select block for Z1.
- Dummy read to address location of Z1\_EXEONLYRAM in Z1 OTP.



#### Dual Code Security Module (DCSM)

- Dummy read to address location of Z1\_EXEONLYSECT in Z1 OTP.
- Dummy read to address location of Z1\_GRABRAM in Z1 OTP.
- Dummy read to address location of Z1\_GRABSECT in Z1 OTP.
- Dummy read to address location of Z2\_OTPSECLOCK in Z2 OTP.
- Dummy read to address location of Z2\_BOOTMODE in Z2 OTP.
- Dummy read to address location of Z2\_LINKPOINTER in Z2 OTP.
- Read to memory map register of Z2\_LINKPOINTER in DCSM module to calculate the address of zone select block for Z2.
- Dummy read to address location of Z2\_EXEONLYRAM in OTP.
- Dummy read to address location of Z2\_EXEONLYSECT in OTP.
- Dummy read to address location of Z2\_GRABRAM in OTP.
- Dummy read to address location of Z2\_GRABSECT in OTP.

#### 1.7.5 Incorporating Code Security in User Applications

Users should perform the following to incorporate security in their application:

- Choose an appropriate link pointer for the zone for which the application will be developed and program the same in the OTP location of the respective zone.
- Program the GRABRAM/GRABSECT location in the OTP location of the respective zone to allocate the required secure RAMs/Flash sectors to that zone.
- Based on the application requirement, program the EXEONLY location in the OTP location of the respective zone to make RAM/Flash sectors allocated to that zone EXEONLY protected.

Once basic security configuration is done, the user must program valid passwords in the appropriate locations and power off the device, perform a device reset, or set the FORCESEC bit (Zx\_CR.15). From this time on, access to debug the contents of secure memory by any means (via JTAG, code running off external/on-chip memory, or other means) requires the correct passwords. Passwords are not needed to run the code out of secure memory such as in a typical end-customer usage; however, access to secure memory contents for debug purposes requires the passwords.

**Note:** Unless valid passwords are programmed in the OTP locations and the device is powered off, a device reset is issued, or the FORCESEC bit (Zx\_CR.15) is set, the zone remains unsecure and all type of accesses to resources allocated to that zone are allowed even though the GRAMRAM/GRABSECT/EXEONLY settings are configured.

#### 1.7.5.1 Environments That Require Security Unlocking

Unsecuring may be required in these typical situations:

- Code development using debuggers (such as CCS). This is the most common environment during the design phase of a product.
- Flash programming using flash utilities such as the CCS On-Chip Flash Programmer plug-in. Flash programming is common during code development and testing. Once the user supplies the necessary passwords, the flash utilities disable the security before attempting to program the flash. Since new devices come with an erased flash, the flash utilities can disable security in new devices without any authorization. However, reprogramming devices that already contain custom passwords require the passwords to be supplied to the flash utilities, in order to unlock the device to enable programming.
- **Custom environment defined by the application.** In addition to the above, access to secure memory contents may be desired in the following situations. These are not suggested operating conditions, as supplying the password from external code would compromise code security.
  - Using the on-chip bootloader to load code or data into secure SARAM or to erase/program the flash.
  - Executing code from on-chip unsecure memory and requiring access to secure memory for a lookup table.

The unsecuring sequence is identical in all of the above situations. This sequence is referred to as the password match flow (PMF) for simplicity. Figure 1-86 explains the sequence of operation that is required each time the user attempts to unsecure a particular zone. Section 1.7.7.1 is listed for clarity.



## 1.7.6 Unsecuring a Zone with Security Enabled (DCSM Password Match Flow)

The DCSM password match flow (PMF) is essentially a sequence of four dummy reads from password locations (PWL) in the Zone Select Block followed by four writes (32-bit writes) to the CSMKEY(0/1/2/3) registers. To determine which Zone Select Block is valid, use the zone link pointer as shown in Figure 1-85. Figure 1-86 shows how PMF helps to initialize the security logic registers and disable security logic.







**NOTE:** Any read of the CSM password would yield 0x0000 until the device is unlocked. These reads are labeled "dummy read" or a "fake read." The application reads the password locations, but will always get 0's no matter what the actual value is. What is important is the actual value of the password. If the actual value is all 0xFFFF, then doing this "dummy read" will unlock the device. If the actual value is all 0x0000, then no matter what the application code does, one will never be able to unlock the device. If the actual value is something other than all 0xFFFF or 0x0000, then when the dummy read is performed, the actual value must match the password the user provided.



Dual Code Security Module (DCSM)

#### 1.7.7 Unsecuring a Zone with Security Disabled

Even if a zone is not protected with a password (all password locations all ones), the DCSM will lock the zone at reset. Thus, a dummy read operation must still be performed on these zones prior to reading, writing, or programming secure memory if the code performing the access is executing from outside of the DCSM protected memory region. The boot ROM and the default CCS GEL files provided by TI perform this dummy read for convenience.

#### 1.7.7.1 C Code Example to Unsecure C28x Zone 1

```
volatile long int *CSM = (volatile long int *)0x000B90;
                                                          //CSM register file
volatile long int *CSMPWL = (volatile long int *)0x003D7A18; //CSM Password location (assuming
default Zone sel block)
volatile int tmp;
int I;
// Read the 128-bits of the password locations (PWL)
11
for (I=0; i<4; I++) tmp = *CSMPWL++;
// If the password locations (CSMPWL) are all = ones (0xFFFF),
// then the zone will now be unsecure. If the password
// is not all ones (OxFFFF), then the code below is required
// to unsecure the zone.
// Write the 128-bit password to the CSMKEY registers
// If this password matches that stored in the
// CSLPWL then the zone will become unsecure. If it does not
// match, then the zone will remain secure.
// An example password of:
// 0x111122223333444455556666677778888 is used.
*CSM++ = 0x22221111; // Register Z1_CSMKEY0 at 0xB90
*CSM++ = 0x44443333; // Register Z1_CSMKEY1 at 0xB92
*CSM++ = 0x66665555; // Register Z1_CSMKEY2 at 0xB94
*CSM++ = 0x88887777; // Register Z1_CSMKEY3 at 0xB96
```

#### 1.7.7.2 C Code Example to Resecure C28x Zone 1

```
volatile int *Z1_CR = 0x00B99; //CSMSCR register
//Set FORCESEC bit
*Z1_CR = 0x8000;
```

#### 1.7.8 Environments That Require ECSL Unlocking

The following is a typical situation in which unsecuring ECSL may be required:

 A user develops some main IP, and then hires a subcontractor to create peripheral functions. The subcontractor must be able to run the user's code during debug, but the source code should not be visible.

## 1.7.9 Disabling the ECSL (ECSL Password Match Flow)

ECSL password match flow (PMF) is a sequence of four dummy reads from the password locations (PWL) followed by two writes to KEY registers. Figure 1-87 shows how the PMF helps to initialize the security logic registers and disable security logic.







#### 1.7.9.1 C Code Example to Disable ECSL for C28x Zone 1

```
volatile long int *ECSL = (volatile int *)0x000B90; //ECSL register file
volatile long int *ECSLPWL = (volatile int *)0x003D7A18; //ECSL Password location (assuming
default Zone sel block)
volatile int tmp;
int I;
// Read the 64-bits of the password locations (PWL) \,
// in flash at address 0x3D 7A18 - 0x3D 7A1B
// If the zone is secure, then the values read will
// not actually be loaded into the temp variable, so
// this is called a dummy read.
for (I=0; i<2; I++) tmp = *ECSLPWL++;</pre>
// If the ECSL password locations (ECSLPWL) are all = ones (0xFFFF),
// then the ECSL will now be disbale. If the password
// is not all ones (0xFFFF), then the code below is required
// to disable the ECSL.
// Write the 64-bit password to the CSMKEYx registers
// If this password matches that stored in the
// CSMPWL then ECSL will get disable. If it does not
// match, then the zone will remain secure.
```



```
// An example password of:
// 0x1111222233334444 is used.
*ECSL++ = 0x22221111; // Register Z1_CSMKEY0 at 0xB90
*ECSL++ = 0x44443333; // Register Z1_CSMKEY1 at 0xB92
```

#### 1.7.10 Do's and Don'ts to Protect Security Logic

#### 1.7.10.1 Do's

- Recheck the password stored in the password locations before programming the COFF file using flash utilities.
- The flow of code execution can freely toggle back and forth between secure memory and unsecure memory without compromising security. To access data variables located in secure memory when the zone is secured, code execution must currently be running from secure memory.

#### 1.7.10.2 Dont's

DCSM Registers

- If code security is desired, do not embed the password in your application anywhere other than in the password locations or security can be compromised.
- Do not use 128 bits of all 0s as the password. This automatically secures the zone, regardless of the contents of the CSMKEY register and the code in that zone cannot be debugged nor reprogrammed.
- Do not reset the device during an erase operation on the flash array. This can leave either zeros or an unknown value in the password locations. If the password locations are all zero during a reset, the zone will always be secure, regardless of the contents of the KEY register.

#### 1.7.11 Dual Code Security Module Disclaimer

#### NOTE: Disclaimer: Dual Code Security Module Disclaimer

The Dual Code Security Module (DCSM) included on this device was designed to password-protect the data stored in the associated memory and is warranted by Texas Instruments (TI), in accordance with its standard terms and conditions, to conform to TI's published specifications for the warranty period applicable for this device. TI DOES NOT, HOWEVER, WARRANT OR REPRESENT THAT THE DCSM CANNOT BE COMPROMISED OR BREACHED OR THAT THE DATA STORED IN THE ASSOCIATED MEMORY CANNOT BE ACCESSED THROUGH OTHER MEANS. MOREOVER, EXCEPT AS SET FORTH ABOVE, TI MAKES NO WARRANTIES OR REPRESENTATIONS CONCERNING THE DCSM OR OPERATION OF THIS DEVICE, INCLUDING ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL TI BE LIABLE FOR ANY CONSEQUENTIAL, SPECIAL, INDIRECT, INCIDENTAL, OR PUNITIVE DAMAGES, HOWEVER CAUSED, ARISING IN ANY WAY OUT OF YOUR USE OF THE DCSM OR THIS DEVICE, WHETHER OR NOT TI HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. EXCLUDED DAMAGES INCLUDE, BUT ARE NOT LIMITED TO LOSS OF DATA. LOSS OF GOODWILL. LOSS OF USE OR INTERRUPTION OF BUSINESS OR OTHER ECONOMIC LOSS.

#### 1.8 DCSM Registers

The following sections include the DCSM registers: OTP\_Z1, OTP\_Z2, REGS\_COMMON, REGS\_Z1, and REGS\_Z2.

#### 1.8.1 DCSM\_OTP\_Z1 DCSM Registers

Table 1-114 lists the memory-mapped registers for the DCSM\_OTP\_Z1 DCSM. All register offset addresses not listed in Table 1-114 should be considered as reserved locations and the register contents should not be modified.

| Offset | Acronym        | Register Name                 | Section         |
|--------|----------------|-------------------------------|-----------------|
| 0h     | Z1_LINKPOINTER | Zone 1 Link Pointer in Z1 OTP | Section 1.8.1.1 |
| 2h     | Z1_OTPSECLOCK  | Secure JTAG Lock in Z1 OTP    | Section 1.8.1.2 |
| 4h     | Z1_BOOTMODE    | Boot Mode in Z1 OTP           | Section 1.8.1.3 |

#### Table 1-114. DCSM\_OTP\_Z1 DCSM REGISTERS



DCSM Registers

#### 1.8.1.1 Z1\_LINKPOINTER Register (offset = 0h) [reset = C000000h]

Z1\_LINKPOINTER is shown in Figure 1-88 and described in Table 1-115.

Zone 1 Link Pointer in Z1 OTP

|     |             | Fig | ure 1-88. Z1_ | LINKPOINTEF | Register |    |    |
|-----|-------------|-----|---------------|-------------|----------|----|----|
| 31  | 30          | 29  | 28            | 27          | 26       | 25 | 24 |
| Res | erved       |     |               | LINKPO      | DINTER   |    |    |
| R·  | -3h         |     |               | R-          | 0h       |    |    |
| 23  | 22          | 21  | 20            | 19          | 18       | 17 | 16 |
|     | LINKPOINTER |     |               |             |          |    |    |
|     |             |     | R-            | 0h          |          |    |    |
| 15  | 14          | 13  | 12            | 11          | 10       | 9  | 8  |
|     | LINKPOINTER |     |               |             |          |    |    |
|     | R-0h        |     |               |             |          |    |    |
| 7   | 6           | 5   | 4             | 3           | 2        | 1  | 0  |
|     |             |     | LINKPO        | DINTER      |          |    |    |
|     | R-0h        |     |               |             |          |    |    |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

# Table 1-115. Z1\_LINKPOINTER Register Field Descriptions

| Bit   | Field       | Туре | Reset | Description                                                                  |
|-------|-------------|------|-------|------------------------------------------------------------------------------|
| 31-30 | Reserved    | R    | 3h    | Reserved                                                                     |
| 29-0  | LINKPOINTER | R    | 0h    | Reflect the Link Pointer value to get the Zone Select region for Zone-<br>1. |

#### 1.8.1.2 Z1\_OTPSECLOCK Register (offset = 2h) [reset = Fh]

Z1\_OTPSECLOCK is shown in Figure 1-89 and described in Table 1-116.

Secure JTAG Lock in Z1 OTP

## Figure 1-89. Z1\_OTPSECLOCK Register

| 31 | 30       | 29    | 28   | 27       | 26 | 25 | 24 |  |  |
|----|----------|-------|------|----------|----|----|----|--|--|
|    | Reserved |       |      |          |    |    |    |  |  |
|    | R-0h     |       |      |          |    |    |    |  |  |
| 23 | 22       | 21    | 20   | 19       | 18 | 17 | 16 |  |  |
|    | Reserved |       |      |          |    |    |    |  |  |
|    | R-0h     |       |      |          |    |    |    |  |  |
| 15 | 14       | 13    | 12   | 11       | 10 | 9  | 8  |  |  |
|    |          |       | Rese | rved     |    |    |    |  |  |
|    |          |       | R-0  | Dh       |    |    |    |  |  |
| 7  | 6        | 5     | 4    | 3        | 2  | 1  | 0  |  |  |
|    | Rese     | erved |      | JTAGLOCK |    |    |    |  |  |
|    | R-       | R-0h  |      |          | R- | Fh |    |  |  |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

## Table 1-116. Z1\_OTPSECLOCK Register Field Descriptions

| Bit   | Field    | Туре | Reset | Description                                                                                                                                                |
|-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Reserved | R    | 0h    | Reserved                                                                                                                                                   |
| 15-4  | Reserved | R    | 0h    | Reserved                                                                                                                                                   |
| 3-0   | JTAGLOCK | R    | Fh    | Locks JTAG/Emulation access if value is other than '1111'.<br>1111 : JTAG/Emulation access is allowed.<br>Other Value : JTAG/Emulation access not allowed. |

#### 1.8.1.3 Z1\_BOOTMODE Register (offset = 4h) [reset = 0h]

Z1\_BOOTMODE is shown in Figure 1-90 and described in Table 1-117.

Boot Mode in Z1 OTP

#### Figure 1-90. Z1\_BOOTMODE Register

| 24 |
|----|
|    |
|    |
|    |
| 16 |
|    |
|    |
| 8  |
|    |
|    |
| 0  |
|    |
|    |
|    |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-117. Z1\_BOOTMODE Register Field Descriptions

| Bit   | Field     | Туре | Reset | Description                                                                                                           |
|-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 31-16 | OTP_BMODE | R    | 0h    | This field gets loaded with Z1_BOOTMODE[31:16] when a dummy read is issued to address location of Z1_BOOTMODE in OTP. |
| 15-0  | OTP_KEY   | R    | 0h    | This field gets loaded with Z1_BOOTMODE[15:0] when a dummy read is issued to address location of Z1_BOOTMODE in OTP.  |

## 1.8.2 DCSM\_OTP\_Z2 DCSM Registers

Table 1-118 lists the memory-mapped registers for the DCSM\_OTP\_Z2 DCSM. All register offset addresses not listed in Table 1-118 should be considered as reserved locations and the register contents should not be modified.

| Offset | Acronym        | Register Name                 | Section         |
|--------|----------------|-------------------------------|-----------------|
| 0h     | Z2_LINKPOINTER | Zone 1 Link Pointer in Z2 OTP | Section 1.8.2.1 |
| 2h     | Z2_OTPSECLOCK  | Secure JTAG Lock in Z2 OTP    | Section 1.8.2.2 |
| 4h     | Z2_BOOTMODE    | Boot Mode in Z2 OTP           | Section 1.8.2.3 |

#### Table 1-118. DCSM\_OTP\_Z2 DCSM REGISTERS

## 1.8.2.1 Z2\_LINKPOINTER Register (offset = 0h) [reset = C0000000h]

Z2\_LINKPOINTER is shown in Figure 1-91 and described in Table 1-119.

Zone 1 Link Pointer in Z2 OTP

|      | Figure 1-91. Z2_LINKPOINTER Register |    |       |        |        |    |    |
|------|--------------------------------------|----|-------|--------|--------|----|----|
| 31   | 30                                   | 29 | 28    | 27     | 26     | 25 | 24 |
| Rese | erved                                |    |       | LINKPO | DINTER |    |    |
| R-   | -3h                                  |    |       | R-     | Oh     |    |    |
| 23   | 22                                   | 21 | 20    | 19     | 18     | 17 | 16 |
|      |                                      |    | LINKP | DINTER |        |    |    |
|      |                                      |    | R·    | -0h    |        |    |    |
| 15   | 14                                   | 13 | 12    | 11     | 10     | 9  | 8  |
|      |                                      |    | LINKP | DINTER |        |    |    |
|      |                                      |    | R     | -0h    |        |    |    |
| 7    | 6                                    | 5  | 4     | 3      | 2      | 1  | 0  |
|      |                                      |    | LINKP | DINTER |        |    |    |
|      |                                      |    | -     |        |        |    |    |

R-0h

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-119. Z2\_LINKPOINTER Register Field Descriptions

| Bit   | Field       | Туре | Reset | Description                                                                  |
|-------|-------------|------|-------|------------------------------------------------------------------------------|
| 31-30 | Reserved    | R    | 3h    | Reserved                                                                     |
| 29-0  | LINKPOINTER | R    | 0h    | Reflect the Link Pointer value to get the Zone Select region for Zone-<br>2. |

#### 1.8.2.2 Z2\_OTPSECLOCK Register (offset = 2h) [reset = Fh]

Z2\_OTPSECLOCK is shown in Figure 1-92 and described in Table 1-120.

Secure JTAG Lock in Z2 OTP

|    | Figure 1-92. Z2_OTPSECLOCK Register |       |      |          |     |    |    |  |
|----|-------------------------------------|-------|------|----------|-----|----|----|--|
| 31 | 30                                  | 29    | 28   | 27       | 26  | 25 | 24 |  |
|    |                                     |       | Rese | erved    |     |    |    |  |
|    | R-0h                                |       |      |          |     |    |    |  |
| 23 | 22                                  | 21    | 20   | 19       | 18  | 17 | 16 |  |
|    | Reserved                            |       |      |          |     |    |    |  |
|    |                                     |       | R-   | 0h       |     |    |    |  |
| 15 | 14                                  | 13    | 12   | 11       | 10  | 9  | 8  |  |
|    |                                     |       | Rese | erved    |     |    |    |  |
|    |                                     |       | R-   | 0h       |     |    |    |  |
| 7  | 6                                   | 5     | 4    | 3        | 2   | 1  | 0  |  |
|    | Res                                 | erved |      | JTAGLOCK |     |    |    |  |
|    | R-0h                                |       |      |          | R-f | Fh |    |  |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-120. Z2\_OTPSECLOCK Register Field Descriptions

| Bit   | Field    | Туре | Reset | Description                                                                                                                                                |
|-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Reserved | R    | 0h    | Reserved                                                                                                                                                   |
| 15-4  | Reserved | R    | 0h    | Reserved                                                                                                                                                   |
| 3-0   | JTAGLOCK | R    | Fh    | Locks JTAG/Emulation access if value is other than '1111'.<br>1111 : JTAG/Emulation access is allowed.<br>Other Value : JTAG/Emulation access not allowed. |

#### 1.8.2.3 Z2\_BOOTMODE Register (offset = 4h) [reset = 0h]

Z2\_BOOTMODE is shown in Figure 1-93 and described in Table 1-121.

Boot Mode in Z2 OTP

#### Figure 1-93. Z2\_BOOTMODE Register

|    |           | -  |       |       | -  |    |    |  |  |
|----|-----------|----|-------|-------|----|----|----|--|--|
| 31 | 30        | 29 | 28    | 27    | 26 | 25 | 24 |  |  |
|    | OTP_BMODE |    |       |       |    |    |    |  |  |
|    | R-0h      |    |       |       |    |    |    |  |  |
| 23 | 22        | 21 | 20    | 19    | 18 | 17 | 16 |  |  |
|    |           |    | OTP_E | BMODE |    |    |    |  |  |
|    | R-0h      |    |       |       |    |    |    |  |  |
| 15 | 14        | 13 | 12    | 11    | 10 | 9  | 8  |  |  |
|    |           |    | OTP   | _KEY  |    |    |    |  |  |
|    |           |    | R     | -0h   |    |    |    |  |  |
| 7  | 6         | 5  | 4     | 3     | 2  | 1  | 0  |  |  |
|    |           |    | OTP   | _KEY  |    |    |    |  |  |
|    |           |    | R     | -0h   |    |    |    |  |  |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-121. Z2\_BOOTMODE Register Field Descriptions

| Bit   | Field     | Туре | Reset | Description                                                                                                           |
|-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 31-16 | OTP_BMODE | R    | 0h    | This field gets loaded with Z2_BOOTMODE[31:16] when a dummy read is issued to address location of Z2_BOOTMODE in OTP. |
| 15-0  | OTP_KEY   | R    | 0h    | This field gets loaded with Z2_BOOTMODE[15:0] when a dummy read is issued to address location of Z2_BOOTMODE in OTP.  |

#### 1.8.3 DCSM\_REGS\_COMMON DCSM Registers

Table 1-122 lists the memory-mapped registers for the DCSM\_REGS\_COMMON DCSM. All register offset addresses not listed in Table 1-122 should be considered as reserved locations and the register contents should not be modified.

| Offset | Acronym  | Register Name                    | Section         |
|--------|----------|----------------------------------|-----------------|
| 0h     | FLSEM    | Flash Wrapper Semaphore Register | Section 1.8.3.1 |
| 2h     | SECTSTAT | Sectors Status Register          | Section 1.8.3.2 |
| 4h     | RAMSTAT  | RAM Status Register              | Section 1.8.3.3 |

#### Table 1-122. DCSM\_REGS\_COMMON DCSM REGISTERS

#### 1.8.3.1 FLSEM Register (offset = 0h) [reset = 0h]

FLSEM is shown in Figure 1-94 and described in Table 1-123.

Flash Wrapper Semaphore Register

|      | Figure 1-94. FLSEM Register |    |      |       |    |     |      |  |  |  |
|------|-----------------------------|----|------|-------|----|-----|------|--|--|--|
| 31   | 30                          | 29 | 28   | 27    | 26 | 25  | 24   |  |  |  |
|      | Reserved                    |    |      |       |    |     |      |  |  |  |
| R-0h |                             |    |      |       |    |     |      |  |  |  |
| 23   | 22                          | 21 | 20   | 19    | 18 | 17  | 16   |  |  |  |
|      |                             |    | Rese | erved |    |     |      |  |  |  |
|      |                             |    | R-   | 0h    |    |     |      |  |  |  |
| 15   | 14                          | 13 | 12   | 11    | 10 | 9   | 8    |  |  |  |
|      |                             |    | K    | ΞY    |    |     |      |  |  |  |
|      | W-0h                        |    |      |       |    |     |      |  |  |  |
| 7    | 6                           | 5  | 4    | 3     | 2  | 1   | 0    |  |  |  |
|      | Reserved                    |    |      |       |    |     |      |  |  |  |
| R-0h |                             |    |      |       |    | R/V | V-0h |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

| Bit   | Field    | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Reserved | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15-8  | KEY      | W    | 0h    | Writing a value 0xA5 into this field will allow the writing of the SEM bits, else writes are ignored. Reads will return 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7-2   | Reserved | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1-0   | SEM      | R/W  | Oh    | <ul> <li>00 : C28X Flash Wrapper registers can be written by code running from anywhere without any restriction.</li> <li>01 : Flash Wrapper registers can be written by code running from Zone1 security zone.</li> <li>10 : C28X Flash Wrapper registers can be written by code running from Zone2 security zone</li> <li>11 : C28X Flash Wrapper registers can be written by code running from anywhere without any restriction</li> <li>Allowed State Transitions in this field.</li> <li>00 - 11 : Code running from anywhere.</li> <li>11 - 00 : Not allowed.</li> <li>00/11 - 01 : Code running from Zone1 only can perform this transition.</li> <li>01 - 00/11 : Code running from Zone2 only can perform this transition.</li> </ul> |

#### Table 1-123. FLSEM Register Field Descriptions

10 - 00/11 : Code running from Zone2 can perform this transition

#### 1.8.3.2 SECTSTAT Register (offset = 2h) [reset = 0h]

SECTSTAT is shown in Figure 1-95 and described in Table 1-124.

Sectors Status Register

## Figure 1-95. SECTSTAT Register



LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-124. SECTSTAT Register Field Descriptions

| Bit   | Field        | Туре | Reset | Description                                                                                                                                                                                                                    |
|-------|--------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20 | Reserved     | R    | 0h    | Reserved                                                                                                                                                                                                                       |
| 19-18 | STATUS_SECTJ | R    | 0h    | Reflects the status of flash sector J.<br>00 : Sector is in-accessible<br>01 : Sector belongs to Zone-1.<br>10 : Sector belongs to Zone-2.<br>11: Sector is un-secure and code running in both zone have full<br>access to it. |
| 17-16 | STATUS_SECTI | R    | Oh    | Reflects the status of flash sector I.<br>00 : Sector is in-accessible<br>01 : Sector belongs to Zone-1.<br>10 : Sector belongs to Zone-2.<br>11: Sector is un-secure and code running in both zone have full<br>access to it. |
| 15-14 | STATUS_SECTH | R    | Oh    | Reflects the status of flash sector H.<br>00 : Sector is in-accessible<br>01 : Sector belongs to Zone-1.<br>10 : Sector belongs to Zone-2.<br>11: Sector is un-secure and code running in both zone have full<br>access to it. |
| 13-12 | STATUS_SECTG | R    | 0h    | Reflects the status of flash sector G.00 : Sector is in-accessible01 : Sector belongs to Zone-1.10 : Sector belongs to Zone-2.11: Sector is un-secure and code running in both zone have fullaccess to it.                     |
| 11-10 | STATUS_SECTF | R    | Oh    | Reflects the status of flash sector F.00 : Sector is in-accessible01 : Sector belongs to Zone-1.10 : Sector belongs to Zone-2.11: Sector is un-secure and code running in both zone have fullaccess to it.                     |
| 9-8   | STATUS_SECTE | R    | Oh    | Reflects the status of flash sector E.<br>00 : Sector is in-accessible<br>01 : Sector belongs to Zone-1.<br>10 : Sector belongs to Zone-2.<br>11: Sector is un-secure and code running in both zone have full<br>access to it. |



| Bit | Field        | Туре | Reset | Description                                                                                                                                                                                                                    |
|-----|--------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-6 | STATUS_SECTD | R    | Oh    | Reflects the status of flash sector D.<br>00 : Sector is in-accessible<br>01 : Sector belongs to Zone-1.<br>10 : Sector belongs to Zone-2.<br>11: Sector is un-secure and code running in both zone have full<br>access to it. |
| 5-4 | STATUS_SECTC | R    | Oh    | Reflects the status of flash sector C.<br>00 : Sector is in-accessible<br>01 : Sector belongs to Zone-1.<br>10 : Sector belongs to Zone-2.<br>11: Sector is un-secure and code running in both zone have full<br>access to it. |
| 3-2 | STATUS_SECTB | R    | Oh    | Reflects the status of flash sector B.<br>00 : Sector is in-accessible<br>01 : Sector belongs to Zone-1.<br>10 : Sector belongs to Zone-2.<br>11: Sector is un-secure and code running in both zone have full<br>access to it. |
| 1-0 | STATUS_SECTA | R    | Oh    | Reflects the status of flash sector A.<br>00 : Sector is in-accessible<br>01 : Sector belongs to Zone-1.<br>10 : Sector belongs to Zone-2.<br>11: Sector is un-secure and code running in both zone have full<br>access to it. |

#### 1.8.3.3 RAMSTAT Register (offset = 4h) [reset = 0h]

RAMSTAT is shown in Figure 1-96 and described in Table 1-125.

**RAM Status Register** 



LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-125. RAMSTAT Register Field Descriptions

| Bit   | Field       | Туре | Reset | Description                                                                                                                                                                                                |
|-------|-------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Reserved    | R    | 0h    | Reserved                                                                                                                                                                                                   |
| 15-8  | Reserved    | R    | 0h    | Reserved                                                                                                                                                                                                   |
| 7-6   | STATUS_RAM3 | R    | Oh    | Reflects the status of L3 RAM.<br>00 : RAM is in-accessible<br>01 : RAM belongs to Zone-1.<br>10 : RAM belongs to Zone-2.<br>11: RAM is un-secure and code running in both zone have full<br>access to it. |
| 5-4   | STATUS_RAM2 | R    | Oh    | Reflects the status of L2 RAM.<br>00 : RAM is in-accessible<br>01 : RAM belongs to Zone-1.<br>10 : RAM belongs to Zone-2.<br>11: RAM is un-secure and code running in both zone have full<br>access to it. |
| 3-2   | STATUS_RAM1 | R    | Oh    | Reflects the status of L1 RAM.<br>00 : RAM is in-accessible<br>01 : RAM belongs to Zone-1.<br>10 : RAM belongs to Zone-2.<br>11: RAM is un-secure and code running in both zone have full<br>access to it. |
| 1-0   | STATUS_RAM0 | R    | Oh    | Reflects the status of L0 RAM.<br>00 : RAM is in-accessible<br>01 : RAM belongs to Zone-1.<br>10 : RAM belongs to Zone-2.<br>11: RAM is un-secure and code running in both zone have full<br>access to it. |

## 1.8.4 DCSM\_REGS\_Z1 DCSM Registers

Table 1-126 lists the memory-mapped registers for the DCSM\_REGS\_Z1 DCSM. All register offset addresses not listed in Table 1-126 should be considered as reserved locations and the register contents should not be modified.

TEXAS INSTRUMENTS

www.ti.com

DCSM Registers

## Table 1-126. DCSM\_REGS\_Z1 DCSM REGISTERS

| Offset | Acronym         | Register Name                             | Section          |
|--------|-----------------|-------------------------------------------|------------------|
| 0h     | Z1_LINKPOINTER  | Zone 1 Link Pointer                       | Section 1.8.4.1  |
| 2h     | Z1_OTPSECLOCK   | Zone 1 OTP Secure JTAG lock               | Section 1.8.4.2  |
| 4h     | Z1_BOOTMODE     | Boot Mode                                 | Section 1.8.4.3  |
| 10h    | Z1_CSMKEY0      | Zone 1 CSM Key 0                          | Section 1.8.4.4  |
| 12h    | Z1_CSMKEY1      | Zone 1 CSM Key 1                          | Section 1.8.4.5  |
| 14h    | Z1_CSMKEY2      | Zone 1 CSM Key 2                          | Section 1.8.4.6  |
| 16h    | Z1_CSMKEY3      | Zone 1 CSM Key 3                          | Section 1.8.4.7  |
| 19h    | Z1_CR           | Zone 1 CSM Control Register               | Section 1.8.4.8  |
| 1Ah    | Z1_GRABSECTR    | Zone 1 Grab Flash Sectors Register        | Section 1.8.4.9  |
| 1Ch    | Z1_GRABRAMR     | Zone 1 Grab RAM Blocks Register           | Section 1.8.4.10 |
| 1Eh    | Z1_EXEONLYSECTR | Zone 1 Flash Execute_Only Sector Register | Section 1.8.4.11 |
| 20h    | Z1_EXEONLYRAMR  | Zone 1 RAM Execute_Only Block Register    | Section 1.8.4.12 |

## 1.8.4.1 Z1\_LINKPOINTER Register (offset = 0h) [reset = C000000h]

Z1\_LINKPOINTER is shown in Figure 1-97 and described in Table 1-127.

Zone 1 Link Pointer

| Figure 1-97. Z1_LINKPOINTER Register |       |    |        |        |        |    |    |  |  |
|--------------------------------------|-------|----|--------|--------|--------|----|----|--|--|
| 31                                   | 30    | 29 | 28     | 27     | 26     | 25 | 24 |  |  |
| Rese                                 | erved |    |        | LINKPO | DINTER |    |    |  |  |
| R-                                   | -3h   |    |        | R-     | 0h     |    |    |  |  |
| 23                                   | 22    | 21 | 20     | 19     | 18     | 17 | 16 |  |  |
|                                      |       |    | LINKPO | DINTER |        |    |    |  |  |
|                                      |       |    | R-     | 0h     |        |    |    |  |  |
| 15                                   | 14    | 13 | 12     | 11     | 10     | 9  | 8  |  |  |
|                                      |       |    | LINKPO | DINTER |        |    |    |  |  |
|                                      |       |    | R-     | 0h     |        |    |    |  |  |
| 7                                    | 6     | 5  | 4      | 3      | 2      | 1  | 0  |  |  |
|                                      |       |    | LINKPO | DINTER |        |    |    |  |  |
|                                      |       |    | R-     | 0h     |        |    |    |  |  |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-127. Z1\_LINKPOINTER Register Field Descriptions

| Bit   | Field       | Туре | Reset | Description                                                                  |
|-------|-------------|------|-------|------------------------------------------------------------------------------|
| 31-30 | Reserved    | R    | 3h    | Reserved                                                                     |
| 29-0  | LINKPOINTER | R    | 0h    | Reflect the Link Pointer value to get the Zone Select region for Zone-<br>1. |

## 1.8.4.2 Z1\_OTPSECLOCK Register (offset = 2h) [reset = Fh]

Z1\_OTPSECLOCK is shown in Figure 1-98 and described in Table 1-128.

Zone 1 OTP Secure JTAG lock

| Figure 1-98. 21_0TPSECLOCK Register |          |    |       |      |          |    |    |  |  |  |
|-------------------------------------|----------|----|-------|------|----------|----|----|--|--|--|
| 31                                  | 30       | 29 | 28    | 27   | 26       | 25 | 24 |  |  |  |
|                                     | Reserved |    |       |      |          |    |    |  |  |  |
| R-0h                                |          |    |       |      |          |    |    |  |  |  |
| 23                                  | 22       | 21 | 20    | 19   | 18       | 17 | 16 |  |  |  |
|                                     |          |    | Reser | ved  |          |    |    |  |  |  |
|                                     |          |    | R-0   | h    |          |    |    |  |  |  |
| 15                                  | 14       | 13 | 12    | 11   | 10       | 9  | 8  |  |  |  |
|                                     |          |    | Reser | ved  |          |    |    |  |  |  |
|                                     | R-0h     |    |       |      |          |    |    |  |  |  |
| 7                                   | 6        | 5  | 4     | 3    | 2        | 1  | 0  |  |  |  |
|                                     | Reserved |    |       |      | JTAGLOCK |    |    |  |  |  |
| R-0h                                |          |    |       | R-Fh |          |    |    |  |  |  |

## Figure 1-98. Z1\_OTPSECLOCK Register

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-128. Z1\_OTPSECLOCK Register Field Descriptions

| Bit   | Field    | Туре | Reset | Description                                                                                                                                                |
|-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Reserved | R    | 0h    | Reserved                                                                                                                                                   |
| 15-4  | Reserved | R    | 0h    | Reserved                                                                                                                                                   |
| 3-0   | JTAGLOCK | R    | Fh    | Locks JTAG/Emulation access if value is other than '1111'.<br>1111 : JTAG/Emulation access is allowed.<br>Other Value : JTAG/Emulation access not allowed. |

## 1.8.4.3 Z1\_BOOTMODE Register (offset = 4h) [reset = 0h]

Z1\_BOOTMODE is shown in Figure 1-99 and described in Table 1-129.

#### Boot Mode

## Figure 1-99. Z1\_BOOTMODE Register

|           |    | -  |       |      | -  |    |    |  |  |
|-----------|----|----|-------|------|----|----|----|--|--|
| 31        | 30 | 29 | 28    | 27   | 26 | 25 | 24 |  |  |
| OTP_BMODE |    |    |       |      |    |    |    |  |  |
| R-0h      |    |    |       |      |    |    |    |  |  |
| 23        | 22 | 21 | 20    | 19   | 18 | 17 | 16 |  |  |
|           |    |    | OTP_E | MODE |    |    |    |  |  |
| R-0h      |    |    |       |      |    |    |    |  |  |
| 15        | 14 | 13 | 12    | 11   | 10 | 9  | 8  |  |  |
|           |    |    | OTP   | KEY  |    |    |    |  |  |
| R-0h      |    |    |       |      |    |    |    |  |  |
| 7         | 6  | 5  | 4     | 3    | 2  | 1  | 0  |  |  |
|           |    |    | OTP_  | _KEY |    |    |    |  |  |
| R-0h      |    |    |       |      |    |    |    |  |  |
|           |    |    |       |      |    |    |    |  |  |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

## Table 1-129. Z1\_BOOTMODE Register Field Descriptions

| Bit   | Field     | Туре | Reset | Description                                                                                                           |
|-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 31-16 | OTP_BMODE | R Oh |       | This field gets loaded with Z1_BOOTMODE[31:16] when a dummy read is issued to address location of Z1_BOOTMODE in OTP. |
| 15-0  | OTP_KEY   | R    | 0h    | This field gets loaded with Z1_BOOTMODE[15:0] when a dummy read is issued to address location of Z1_BOOTMODE in OTP.  |



DCSM Registers

## 1.8.4.4 Z1\_CSMKEY0 Register (offset = 10h) [reset = 0h]

Z1\_CSMKEY0 is shown in Figure 1-100 and described in Table 1-130.

Zone 1 CSM Key 0

#### Figure 1-100. Z1\_CSMKEY0 Register

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | Z1_CSMKEY0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    | R/W-0h     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-130. Z1\_CSMKEY0 Register Field Descriptions

| Bit  | t  | Field      | Туре | Reset | Description      |
|------|----|------------|------|-------|------------------|
| 31-0 | -0 | Z1_CSMKEY0 | R/W  | 0h    | Zone 1 CSM Key 0 |



### 1.8.4.5 Z1\_CSMKEY1 Register (offset = 12h) [reset = 0h]

Z1\_CSMKEY1 is shown in Figure 1-101 and described in Table 1-131.

Zone 1 CSM Key 1

### Figure 1-101. Z1\_CSMKEY1 Register

R/W-0h

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-131. Z1\_CSMKEY1 Register Field Descriptions

| Bit  | Field      | Туре | Reset | Description      |
|------|------------|------|-------|------------------|
| 31-0 | Z1_CSMKEY1 | R/W  | 0h    | Zone 1 CSM Key 1 |



DCSM Registers

### 1.8.4.6 Z1\_CSMKEY2 Register (offset = 14h) [reset = 0h]

Z1\_CSMKEY2 is shown in Figure 1-102 and described in Table 1-132.

Zone 1 CSM Key 2

### Figure 1-102. Z1\_CSMKEY2 Register

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | Z1_CSMKEY2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    | R/W-0h     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-132. Z1\_CSMKEY2 Register Field Descriptions

| Bit  | : | Field      | Туре | Reset | Description      |
|------|---|------------|------|-------|------------------|
| 31-0 | 0 | Z1_CSMKEY2 | R/W  | 0h    | Zone 1 CSM Key 2 |



### 1.8.4.7 Z1\_CSMKEY3 Register (offset = 16h) [reset = 0h]

Z1\_CSMKEY3 is shown in Figure 1-103 and described in Table 1-133.

Zone 1 CSM Key 3

### Figure 1-103. Z1\_CSMKEY3 Register

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | Z1_CSMKEY3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    | R/W-0h     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-133. Z1\_CSMKEY3 Register Field Descriptions

| Bit  | Field      | Туре | Reset | Description      |
|------|------------|------|-------|------------------|
| 31-0 | Z1_CSMKEY3 | R/W  | 0h    | Zone 1 CSM Key 3 |

### 1.8.4.8 Z1\_CR Register (offset = 19h) [reset = 8h]

Z1\_CR is shown in Figure 1-104 and described in Table 1-134.

Zone 1 CSM Control Register

### Figure 1-104. Z1\_CR Register

| 15       | 14    | 13    | 12     | 11       | 10 | 9        | 8 |
|----------|-------|-------|--------|----------|----|----------|---|
| FORCESEC |       |       |        | Reserved |    |          |   |
| W-0h     |       |       |        | R-0h     |    |          |   |
| 7        | 6     | 5     | 4      | 3        | 2  | 1        | 0 |
| Reserved | ARMED | MATCH | ALLONE | ALLZERO  |    | Reserved |   |
| R-0h     | R-0h  | R-0h  | R-0h   | R-1h     |    | R-0h     |   |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

| Bit  | Field    | Туре | Reset | Description                                                                                                                                                             |
|------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | FORCESEC | W    | 0h    | A write '1' to this fields resets the state of zone. If zone is unlocked, it'll lock(secure) the zone and also resets all the bits in this register.                    |
| 14-8 | Reserved | R    | 0h    | Reserved                                                                                                                                                                |
| 7    | Reserved | R    | 0h    | Reserved                                                                                                                                                                |
| 6    | ARMED    | R    | Oh    | <ul> <li>0 : Dummy read to CSM Password locations in OTP hasn't been performed.</li> <li>1 : Dummy read to CSM Password locations in OTP has been performed.</li> </ul> |
| 5    | МАТСН    | R    | Oh    | Indiacates the state of Zone.<br>0 : Zone is in lock(secure) state.<br>1 : Zone is in unlock(non-secure) state.                                                         |
| 4    | ALLONE   | R    | Oh    | Indicates the state of CSM passowrds.<br>0 : CSM Passwords are not all ones.<br>1 : CSM Passwords are all ones and zone is in unlock state.                             |
| 3    | ALLZERO  | R    | 1h    | Indicates the state of CSM passowrds.<br>0 : CSM Passwords are not all zeros.<br>1 : CSM Passwords are all zero and device is permanently locked.                       |
| 2-0  | Reserved | R    | 0h    | Reserved                                                                                                                                                                |

### Table 1-134. Z1\_CR Register Field Descriptions

### 1.8.4.9 Z1\_GRABSECTR Register (offset = 1Ah) [reset = 0h]

Z1\_GRABSECTR is shown in Figure 1-105 and described in Table 1-135.

Zone 1 Grab Flash Sectors Register



### Figure 1-105. Z1\_GRABSECTR Register

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

| Bit   | Field      | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20 | Reserved   | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                                                                           |
| 19-18 | GRAB_SECTJ | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABSECT[19:18] when a read is issued to address location of Z1_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector J is inaccessible.</li> <li>01 : Request to allocate Flash Sector J to Zone1.</li> <li>10 : Request to allocate Flash Sector J to Zone2.</li> <li>11 : Request to make Flash sector J Non-Secure.</li> </ul> |
| 17-16 | GRAB_SECTI | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABSECT[17:16] when a read is issued to address location of Z1_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector I is inaccessible.</li> <li>01 : Request to allocate Flash Sector I to Zone1.</li> <li>10 : Request to allocate Flash Sector I to Zone2.</li> <li>11 : Request to make Flash sector I Non-Secure.</li> </ul> |
| 15-14 | GRAB_SECTH | R    | Oh    | Value in this field gets loaded from Z1_GRABSECT[15:14] when a<br>read is issued to address location of Z1_GRABSECT in OTP.<br>00 : Invalid. Flash Sector H is inaccessible.<br>01 : Request to allocate Flash Sector H to Zone1.<br>10 : Request to allocate Flash Sector H to Zone2.<br>11 : Request to make Flash sector H Non-Secure.                                          |
| 13-12 | GRAB_SECTG | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABSECT[13:12] when a read is issued to address location of Z1_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector G is inaccessible.</li> <li>01 : Request to allocate Flash Sector G to Zone1.</li> <li>10 : Request to allocate Flash Sector G to Zone2.</li> <li>11 : Request to make Flash sector G Non-Secure.</li> </ul> |
| 11-10 | GRAB_SECTF | R    | Oh    | Value in this field gets loaded from Z1_GRABSECT[11:10] when a<br>read is issued to address location of Z1_GRABSECT in OTP.<br>00 : Invalid. Flash Sector F is inaccessible.<br>01 : Request to allocate Flash Sector F to Zone1.<br>10 : Request to allocate Flash Sector F to Zone2.<br>11 : Request to make Flash sector F Non-Secure.                                          |
| 9-8   | GRAB_SECTE | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABSECT[9:8] when a read is issued to address location of Z1_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector E is inaccessible.</li> <li>01 : Request to allocate Flash Sector E to Zone1.</li> <li>10 : Request to allocate Flash Sector E to Zone2.</li> <li>11 : Request to make Flash sector E Non-Secure.</li> </ul>   |

### Table 1-135. Z1\_GRABSECTR Register Field Descriptions



| Bit | Field      | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-6 | GRAB_SECTD | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABSECT[7:6] when a read is issued to address location of Z1_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector D is inaccessible.</li> <li>01 : Request to allocate Flash Sector D to Zone1.</li> <li>10 : Request to allocate Flash Sector D to Zone2.</li> <li>11 : Request to make Flash sector D Non-Secure.</li> </ul> |
| 5-4 | GRAB_SECTC | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABSECT[5:4] when a read is issued to address location of Z1_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector C is inaccessible.</li> <li>01 : Request to allocate Flash Sector C to Zone1.</li> <li>10 : Request to allocate Flash Sector C to Zone2.</li> <li>11 : Request to make Flash sector C Non-Secure.</li> </ul> |
| 3-2 | GRAB_SECTB | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABSECT[3:2] when a read is issued to address location of Z1_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector B is inaccessible.</li> <li>01 : Request to allocate Flash Sector B to Zone1.</li> <li>10 : Request to allocate Flash Sector B to Zone2.</li> <li>11 : Request to make Flash sector B Non-Secure.</li> </ul> |
| 1-0 | GRAB_SECTA | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABSECT[1:0] when a read is issued to address location of Z1_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector A is inaccessible.</li> <li>01 : Request to allocate Flash Sector A to Zone1.</li> <li>10 : Request to allocate Flash Sector A to Zone2.</li> <li>11 : Request to make Flash sector A Non-Secure.</li> </ul> |

### 1.8.4.10 Z1\_GRABRAMR Register (offset = 1Ch) [reset = 0h]

Z1\_GRABRAMR is shown in Figure 1-106 and described in Table 1-136.

Zone 1 Grab RAM Blocks Register



#### LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

| Bit   | Field     | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Reserved  | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                                       |
| 15-8  | Reserved  | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                                       |
| 7-6   | GRAB_RAM3 | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABRAM[7:6] when a read is issued to address location of Z1_GRABRAM in OTP.</li> <li>00 : Invalid. L3 RAM is inaccessible.</li> <li>01 : Request to allocate L3 RAM to Zone1.</li> <li>10 : Request to allocate L3 RAM to Zone2.</li> <li>11 : Request to make L3 RAM Non-Secure.</li> </ul> |
| 5-4   | GRAB_RAM2 | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABRAM[5:4] when a read is issued to address location of Z1_GRABRAM in OTP.</li> <li>00 : Invalid. L2 RAM is inaccessible.</li> <li>01 : Request to allocate L2 RAM to Zone1.</li> <li>10 : Request to allocate L2 RAM to Zone2.</li> <li>11 : Request to make L2 RAM Non-Secure.</li> </ul> |
| 3-2   | GRAB_RAM1 | R    | Oh    | Value in this field gets loaded from Z1_GRABRAM[3:2] when a read<br>is issued to address location of Z1_GRABRAM in OTP.<br>00 : Invalid. L1 RAM is inaccessible.<br>01 : Request to allocate L1 RAM to Zone1.<br>10 : Request to allocate L1 RAM to Zone2.<br>11 : Request to make L1 RAM Non-Secure.                                          |
| 1-0   | GRAB_RAM0 | R    | Oh    | <ul> <li>Value in this field gets loaded from Z1_GRABRAM[1:0] when a read is issued to address location of Z1_GRABRAM in OTP.</li> <li>00 : Invalid. L0 RAM is inaccessible.</li> <li>01 : Request to allocate L0 RAM to Zone1.</li> <li>10 : Request to allocate L0 RAM to Zone2.</li> <li>11 : Request to make L0 RAM Non-Secure.</li> </ul> |

### Table 1-136. Z1\_GRABRAMR Register Field Descriptions



### 1.8.4.11 Z1\_EXEONLYSECTR Register (offset = 1Eh) [reset = 0h]

Z1\_EXEONLYSECTR is shown in Figure 1-107 and described in Table 1-137.

Zone 1 Flash Execute\_Only Sector Register



LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-137. Z1\_EXEONLYSECTR Register Field Descriptions

| Bit   | Field         | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                         |  |
|-------|---------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-16 | Reserved      | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                            |  |
| 15-10 | Reserved      | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                            |  |
| 9     | EXEONLY_SECTJ | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[9:9] when a<br>read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector J (only if It is<br>allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector J (only if it is<br>allocated to Zone1) |  |
| 8     | EXEONLY_SECTI | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[8:8] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector I (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector I (only if it is allocated to Zone1)          |  |
| 7     | EXEONLY_SECTH | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[7:7] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector H (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector H (only if it is allocated to Zone1)          |  |
| 6     | EXEONLY_SECTG | R    | 0h    | Value in this field gets loaded from Z1_EXEONLYSECT[6:6] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector G (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector G (only if it is allocated to Zone1)          |  |
| 5     | EXEONLY_SECTF | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[5:5] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector F (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector F (only if it is allocated to Zone1)          |  |



| Bit | Field         | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                |
|-----|---------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | EXEONLY_SECTE | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[4:4] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector E (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector E (only if it is allocated to Zone1) |
| 3   | EXEONLY_SECTD | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[3:3] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector D (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector D (only if it is allocated to Zone1) |
| 2   | EXEONLY_SECTC | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[2:2] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector C (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector C (only if it is allocated to Zone1) |
| 1   | EXEONLY_SECTB | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[1:1] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector B (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector B (only if it is allocated to Zone1) |
| 0   | EXEONLY_SECTA | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYSECT[0:0] when a read is issued to Z1_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector A (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for Flash Sector A (only if it is allocated to Zone1) |

### 1.8.4.12 Z1\_EXEONLYRAMR Register (offset = 20h) [reset = 0h]

Z1\_EXEONLYRAMR is shown in Figure 1-108 and described in Table 1-138.

Zone 1 RAM Execute\_Only Block Register



#### LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

#### Table 1-138. Z1\_EXEONLYRAMR Register Field Descriptions

| Bit   | Field        | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                 |  |
|-------|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-16 | Reserved     | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                    |  |
| 15-4  | Reserved     | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                    |  |
| 3     | EXEONLY_RAM3 | R    | Oh    | 0h       Value in this field gets loaded from Z1_EXEONLYRAM[3:3] when a read is issued to Z1_EXEONLYRAM address location in OTP.         0 : Execute-Only protection is enabled for L3 RAM (only if it is allocated to Zone1)         1 : Execute-Only protection is disabled for L3 RAM (only if it is allocated to Zone1) |  |
| 2     | EXEONLY_RAM2 | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYRAM[2:2] when a<br>read is issued to Z1_EXEONLYRAM address location in OTP.<br>0 : Execute-Only protection is enabled for L2 RAM (only if it is<br>allocated to Zone1)<br>1 : Execute-Only protection is disabled for L2 RAM (only if it is<br>allocated to Zone1)           |  |
| 1     | EXEONLY_RAM1 | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYRAM[1:1] when a read is issued to Z1_EXEONLYRAM address location in OTP.<br>0 : Execute-Only protection is enabled for L1 RAM (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for L1 RAM (only if it is allocated to Zone1)                    |  |
| 0     | EXEONLY_RAM0 | R    | Oh    | Value in this field gets loaded from Z1_EXEONLYRAM[0:0] when a read is issued to Z1_EXEONLYRAM address location in OTP.<br>0 : Execute-Only protection is enabled for L0 RAM (only if it is allocated to Zone1)<br>1 : Execute-Only protection is disabled for L0 RAM (only if it is allocated to Zone1)                    |  |

### 1.8.5 DCSM\_REGS\_Z2 DCSM Registers

Table 1-139 lists the memory-mapped registers for the DCSM\_REGS\_Z2 DCSM. All register offset addresses not listed in Table 1-139 should be considered as reserved locations and the register contents should not be modified.

# DCSM Registers Table 1-139. DCSM\_REGS\_Z2 DCSM REGISTERS

| Offset | Acronym         | Register Name                             | Section          |
|--------|-----------------|-------------------------------------------|------------------|
| 0h     | Z2_LINKPOINTER  | Zone 2 Link Pointer                       | Section 1.8.5.1  |
| 2h     | Z2_OTPSECLOCK   | Zone 2 OTP Secure JTAG lock               | Section 1.8.5.2  |
| 4h     | Z2_BOOTMODE     | Boot Mode                                 | Section 1.8.5.3  |
| 10h    | Z2_CSMKEY0      | Zone 2 CSM Key 0                          | Section 1.8.5.4  |
| 12h    | Z2_CSMKEY1      | Zone 2 CSM Key 1                          | Section 1.8.5.5  |
| 14h    | Z2_CSMKEY2      | Zone 2 CSM Key 2                          | Section 1.8.5.6  |
| 16h    | Z2_CSMKEY3      | Zone 2 CSM Key 3                          | Section 1.8.5.7  |
| 19h    | Z2_CR           | Zone 2 CSM Control Register               | Section 1.8.5.8  |
| 1Ah    | Z2_GRABSECTR    | Zone 2 Grab Flash Sectors Register        | Section 1.8.5.9  |
| 1Ch    | Z2_GRABRAMR     | Zone 2 Grab RAM Blocks Register           | Section 1.8.5.10 |
| 1Eh    | Z2_EXEONLYSECTR | Zone 2 Flash Execute_Only Sector Register | Section 1.8.5.11 |
| 20h    | Z2_EXEONLYRAMR  | Zone 2 RAM Execute_Only Block Register    | Section 1.8.5.12 |



DCSM Registers

### 1.8.5.1 Z2\_LINKPOINTER Register (offset = 0h) [reset = C0000000h]

Z2\_LINKPOINTER is shown in Figure 1-109 and described in Table 1-140.

Zone 2 Link Pointer

|      |       | i igu |        |        | N Negister |    |    |
|------|-------|-------|--------|--------|------------|----|----|
| 31   | 30    | 29    | 28     | 27     | 26         | 25 | 24 |
| Rese | erved |       |        | LINKPC | DINTER     |    |    |
| R-   | 3h    |       |        | R-     | 0h         |    |    |
| 23   | 22    | 21    | 20     | 19     | 18         | 17 | 16 |
|      |       |       | LINKPO | DINTER |            |    |    |
|      |       |       | R-     | 0h     |            |    |    |
| 15   | 14    | 13    | 12     | 11     | 10         | 9  | 8  |
|      |       |       | LINKPO | DINTER |            |    |    |
|      |       |       | R-     | 0h     |            |    |    |
| 7    | 6     | 5     | 4      | 3      | 2          | 1  | 0  |
|      |       |       | LINKPO | DINTER |            |    |    |
|      |       |       | R-     | 0h     |            |    |    |

## Figure 1-109. Z2\_LINKPOINTER Register

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-140. Z2\_LINKPOINTER Register Field Descriptions

| В   | it  | Field       | Туре | Reset | Description                                                                  |  |
|-----|-----|-------------|------|-------|------------------------------------------------------------------------------|--|
| 31- | -30 | Reserved    | R    | 3h    | Reserved                                                                     |  |
| 29  | -0  | LINKPOINTER | R    | 0h    | Reflect the Link Pointer value to get the Zone Select region for Zone-<br>2. |  |

### 1.8.5.2 Z2\_OTPSECLOCK Register (offset = 2h) [reset = Fh]

Z2\_OTPSECLOCK is shown in Figure 1-110 and described in Table 1-141.

Zone 2 OTP Secure JTAG lock

| Figure 1-110. 22_OTFSECLOCK Register |          |       |      |      |       |      |    |  |  |
|--------------------------------------|----------|-------|------|------|-------|------|----|--|--|
| 31                                   | 30       | 29    | 28   | 27   | 26    | 25   | 24 |  |  |
|                                      | Reserved |       |      |      |       |      |    |  |  |
|                                      | R-0h     |       |      |      |       |      |    |  |  |
| 23                                   | 22       | 21    | 20   | 19   | 18    | 17   | 16 |  |  |
| Reserved                             |          |       |      |      |       |      |    |  |  |
|                                      | R-0h     |       |      |      |       |      |    |  |  |
| 15                                   | 14       | 13    | 12   | 11   | 10    | 9    | 8  |  |  |
|                                      |          |       | Rese | rved |       |      |    |  |  |
|                                      |          |       | R-0  | Dh   |       |      |    |  |  |
| 7                                    | 6        | 5     | 4    | 3    | 2     | 1    | 0  |  |  |
|                                      | Res      | erved |      |      | JTAGI | LOCK |    |  |  |
|                                      | R-0h     |       |      |      | R-    | Fh   |    |  |  |

### Figure 1-110. Z2\_OTPSECLOCK Register

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-141. Z2\_OTPSECLOCK Register Field Descriptions

| Bit   | Field    | Туре | Reset       | Description                                                                                                                                                |
|-------|----------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Reserved | R    | 0h Reserved |                                                                                                                                                            |
| 15-4  | Reserved | R    | 0h          | Reserved                                                                                                                                                   |
| 3-0   | JTAGLOCK | R    | Fh          | Locks JTAG/Emulation access if value is other than '1111'.<br>1111 : JTAG/Emulation access is allowed.<br>Other Value : JTAG/Emulation access not allowed. |

### 1.8.5.3 Z2\_BOOTMODE Register (offset = 4h) [reset = 0h]

Z2\_BOOTMODE is shown in Figure 1-111 and described in Table 1-142.

### Boot Mode

| 24        |  |  |  |  |  |  |  |  |
|-----------|--|--|--|--|--|--|--|--|
| 24        |  |  |  |  |  |  |  |  |
| OTP_BMODE |  |  |  |  |  |  |  |  |
| R-0h      |  |  |  |  |  |  |  |  |
| 16        |  |  |  |  |  |  |  |  |
| OTP_BMODE |  |  |  |  |  |  |  |  |
| R-0h      |  |  |  |  |  |  |  |  |
| 8         |  |  |  |  |  |  |  |  |
|           |  |  |  |  |  |  |  |  |
| R-0h      |  |  |  |  |  |  |  |  |
| 0         |  |  |  |  |  |  |  |  |
|           |  |  |  |  |  |  |  |  |
|           |  |  |  |  |  |  |  |  |
|           |  |  |  |  |  |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-142. Z2\_BOOTMODE Register Field Descriptions

| Bit   | Field     | Туре | Reset | Description                                                                                                           |
|-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 31-16 | OTP_BMODE | R    | 0h    | This field gets loaded with Z2_BOOTMODE[31:16] when a dummy read is issued to address location of Z2_BOOTMODE in OTP. |
| 15-0  | OTP_KEY   | R    | 0h    | This field gets loaded with Z2_BOOTMODE[15:0] when a dummy read is issued to address location of Z2_BOOTMODE in OTP.  |



### 1.8.5.4 Z2\_CSMKEY0 Register (offset = 10h) [reset = 0h]

Z2\_CSMKEY0 is shown in Figure 1-112 and described in Table 1-143.

Zone 2 CSM Key 0

### Figure 1-112. Z2\_CSMKEY0 Register

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | Z  | 2_CS | MKEY | ′0 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/V  | /-0h |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-143. Z2\_CSMKEY0 Register Field Descriptions

| Bit  | Field      | Туре | Reset | Description      |
|------|------------|------|-------|------------------|
| 31-0 | Z2_CSMKEY0 | R/W  | 0h    | Zone 2 CSM Key 0 |



DCSM Registers

### 1.8.5.5 Z2\_CSMKEY1 Register (offset = 12h) [reset = 0h]

Z2\_CSMKEY1 is shown in Figure 1-113 and described in Table 1-144.

Zone 2 CSM Key 1

### Figure 1-113. Z2\_CSMKEY1 Register

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15   | 14         | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | Z  | 2_CS | MKEY | <b>′</b> 1 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/V  | /-0h |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-144. Z2\_CSMKEY1 Register Field Descriptions

| Bit  | : | Field      | Туре | Reset | Description      |
|------|---|------------|------|-------|------------------|
| 31-0 | 0 | Z2_CSMKEY1 | R/W  | 0h    | Zone 2 CSM Key 1 |



### 1.8.5.6 Z2\_CSMKEY2 Register (offset = 14h) [reset = 0h]

Z2\_CSMKEY2 is shown in Figure 1-114 and described in Table 1-145.

Zone 2 CSM Key 2

### Figure 1-114. Z2\_CSMKEY2 Register

| Z2_CSMKEY2 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Z  | 2_CS | MKEY | 2  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

R/W-0h

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-145. Z2\_CSMKEY2 Register Field Descriptions

| Bit | it | Field      | Туре | Reset | Description      |
|-----|----|------------|------|-------|------------------|
| 31- | -0 | Z2_CSMKEY2 | R/W  | 0h    | Zone 2 CSM Key 2 |



DCSM Registers

### 1.8.5.7 Z2\_CSMKEY3 Register (offset = 16h) [reset = 0h]

Z2\_CSMKEY3 is shown in Figure 1-115 and described in Table 1-146.

Zone 2 CSM Key 3

### Figure 1-115. Z2\_CSMKEY3 Register

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | Z  | 2_CS | MKEY | ′3 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/V  | /-0h |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-146. Z2\_CSMKEY3 Register Field Descriptions

| Bit | it | Field      | Туре | Reset | Description      |
|-----|----|------------|------|-------|------------------|
| 31- | -0 | Z2_CSMKEY3 | R/W  | 0h    | Zone 2 CSM Key 3 |

### 1.8.5.8 Z2\_CR Register (offset = 19h) [reset = 8h]

Z2\_CR is shown in Figure 1-116 and described in Table 1-147.

Zone 2 CSM Control Register

### Figure 1-116. Z2\_CR Register

| 15       | 14    | 13    | 12     | 11       | 10 | 9        | 8 |
|----------|-------|-------|--------|----------|----|----------|---|
| FORCESEC |       |       |        | Reserved |    |          |   |
| W-0h     |       |       |        | R-0h     |    |          |   |
| 7        | 6     | 5     | 4      | 3        | 2  | 1        | 0 |
| Reserved | ARMED | MATCH | ALLONE | ALLZERO  |    | Reserved |   |
| R-0h     | R-0h  | R-0h  | R-0h   | R-1h     |    | R-0h     |   |

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

| Bit  | Field    | Туре | Reset | Description                                                                                                                                                             |
|------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | FORCESEC | W    | 0h    | A write '1' to this fields resets the state of zone. If zone is unlocked, it'll lock(secure) the zone and also resets all the bits in this register.                    |
| 14-8 | Reserved | R    | 0h    | Reserved                                                                                                                                                                |
| 7    | Reserved | R    | 0h    | Reserved                                                                                                                                                                |
| 6    | ARMED    | R    | Oh    | <ul> <li>0 : Dummy read to CSM Password locations in OTP hasn't been performed.</li> <li>1 : Dummy read to CSM Password locations in OTP has been performed.</li> </ul> |
| 5    | МАТСН    | R    | Oh    | Indiacates the state of Zone.<br>0 : Zone is in secure state.<br>1 : Zone is in non-secure state.                                                                       |
| 4    | ALLONE   | R    | Oh    | Indicates the state of CSM passowrds.<br>0 : CSM Passwords are not all ones.<br>1 : CSM Passwords are all ones and zone is in unlock state.                             |
| 3    | ALLZERO  | R    | 1h    | Indicates the state of CSM passowrds.<br>0 : CSM Passwords are not all zeros.<br>1 : CSM Passwords are all zero and device is permanently locked.                       |
| 2-0  | Reserved | R    | 0h    | Reserved                                                                                                                                                                |

### Table 1-147. Z2\_CR Register Field Descriptions

### 1.8.5.9 Z2\_GRABSECTR Register (offset = 1Ah) [reset = 0h]

Z2\_GRABSECTR is shown in Figure 1-117 and described in Table 1-148.

Zone 2 Grab Flash Sectors Register



LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

|       |            | Table 1-148. | Z2_GRAB | SECTR Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                  |
|-------|------------|--------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Field      | Туре         | Reset   | Description                                                                                                                                                                                                                                                                                                                                                                        |
| 31-20 | Reserved   | R            | 0h      | Reserved                                                                                                                                                                                                                                                                                                                                                                           |
| 19-18 | GRAB_SECTJ | R            | Oh      | <ul> <li>Value in this field gets loaded from Z2_GRABSECT[19:18] when a read is issued to address location of Z2_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector J is inaccessible.</li> <li>01 : Request to allocate Flash Sector J to Zone1.</li> <li>10 : Request to allocate Flash Sector J to Zone2.</li> <li>11 : Request to make Flash sector J Non-Secure.</li> </ul> |
| 17-16 | GRAB_SECTI | R            | Oh      | <ul> <li>Value in this field gets loaded from Z2_GRABSECT[17:16] when a read is issued to address location of Z2_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector I is inaccessible.</li> <li>01 : Request to allocate Flash Sector I to Zone1.</li> <li>10 : Request to allocate Flash Sector I to Zone2.</li> <li>11 : Request to make Flash sector I Non-Secure.</li> </ul> |
| 15-14 | GRAB_SECTH | R            | 0h      | <ul> <li>Value in this field gets loaded from Z2_GRABSECT[15:14] when a read is issued to address location of Z2_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector H is inaccessible.</li> <li>01 : Request to allocate Flash Sector H to Zone1.</li> <li>10 : Request to allocate Flash Sector H to Zone2.</li> <li>11 : Request to make Flash sector H Non-Secure.</li> </ul> |
| 13-12 | GRAB_SECTG | R            | 0h      | <ul> <li>Value in this field gets loaded from Z2_GRABSECT[13:12] when a read is issued to address location of Z2_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector G is inaccessible.</li> <li>01 : Request to allocate Flash Sector G to Zone1.</li> <li>10 : Request to allocate Flash Sector G to Zone2.</li> <li>11 : Request to make Flash sector G Non-Secure.</li> </ul> |
| 11-10 | GRAB_SECTF | R            | Oh      | Value in this field gets loaded from Z2_GRABSECT[11:10] when a read is issued to address location of Z2_GRABSECT in OTP.<br>00 : Invalid. Flash Sector F is inaccessible.<br>01 : Request to allocate Flash Sector F to Zone1.<br>10 : Request to allocate Flash Sector F to Zone2.                                                                                                |

GRAB\_SECTE

9-8

R

0h

11 : Request to make Flash sector F Non-Secure.

00 : Invalid. Flash Sector E is inaccessible. 01 : Request to allocate Flash Sector E to Zone1. 10 : Request to allocate Flash Sector E to Zone2. 11 : Request to make Flash sector E Non-Secure.

is issued to address location of Z2\_GRABSECT in OTP.

Value in this field gets loaded from Z2\_GRABSECT[9:8] when a read



| Bit | Field      | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-6 | GRAB_SECTD | R    | Oh    | <ul> <li>Value in this field gets loaded from Z2_GRABSECT[7:6] when a read is issued to address location of Z2_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector D is inaccessible.</li> <li>01 : Request to allocate Flash Sector D to Zone1.</li> <li>10 : Request to allocate Flash Sector D to Zone2.</li> <li>11 : Request to make Flash sector D Non-Secure.</li> </ul> |
| 5-4 | GRAB_SECTC | R    | Oh    | <ul> <li>Value in this field gets loaded from Z2_GRABSECT[5:4] when a read is issued to address location of Z2_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector C is inaccessible.</li> <li>01 : Request to allocate Flash Sector C to Zone1.</li> <li>10 : Request to allocate Flash Sector C to Zone2.</li> <li>11 : Request to make Flash sector C Non-Secure.</li> </ul> |
| 3-2 | GRAB_SECTB | R    | Oh    | <ul> <li>Value in this field gets loaded from Z2_GRABSECT[3:2] when a read is issued to address location of Z2_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector B is inaccessible.</li> <li>01 : Request to allocate Flash Sector B to Zone1.</li> <li>10 : Request to allocate Flash Sector B to Zone2.</li> <li>11 : Request to make Flash sector B Non-Secure.</li> </ul> |
| 1-0 | GRAB_SECTA | R    | Oh    | <ul> <li>Value in this field gets loaded from Z2_GRABSECT[1:0] when a read is issued to address location of Z2_GRABSECT in OTP.</li> <li>00 : Invalid. Flash Sector A is inaccessible.</li> <li>01 : Request to allocate Flash Sector A to Zone1.</li> <li>10 : Request to allocate Flash Sector A to Zone2.</li> <li>11 : Request to make Flash sector A Non-Secure.</li> </ul> |

### Table 1-148. Z2\_GRABSECTR Register Field Descriptions (continued)

### 1.8.5.10 Z2\_GRABRAMR Register (offset = 1Ch) [reset = 0h]

Z2\_GRABRAMR is shown in Figure 1-118 and described in Table 1-149.

Zone 2 Grab RAM Blocks Register



#### LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

| Bit   | Field     | Туре | Reset | Description                                                                                                                                                                                                                                                                                           |  |
|-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-16 | Reserved  | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                              |  |
| 15-8  | Reserved  | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                              |  |
| 7-6   | GRAB_RAM3 | R    | Oh    | Value in this field gets loaded from Z2_GRABRAM[7:6] when a re<br>is issued to address location of Z1_GRABRAM in OTP.<br>00 : Invalid. L3 RAM is inaccessible.<br>01 : Request to allocate L3 RAM to Zone1.<br>10 : Request to allocate L3 RAM to Zone2.<br>11 : Request to make L3 RAM Non-Secure.   |  |
| 5-4   | GRAB_RAM2 | R    | Oh    | Value in this field gets loaded from Z2_GRABRAM[5:4] when a read<br>is issued to address location of Z1_GRABRAM in OTP.<br>00 : Invalid. L2 RAM is inaccessible.<br>01 : Request to allocate L2 RAM to Zone1.<br>10 : Request to allocate L2 RAM to Zone2.<br>11 : Request to make L2 RAM Non-Secure. |  |
| 3-2   | GRAB_RAM1 | R    | Oh    | Value in this field gets loaded from Z2_GRABRAM[3:2] when a read<br>is issued to address location of Z1_GRABRAM in OTP.<br>00 : Invalid. L1 RAM is inaccessible.<br>01 : Request to allocate L1 RAM to Zone1.<br>10 : Request to allocate L1 RAM to Zone2.<br>11 : Request to make L1 RAM Non-Secure. |  |
| 1-0   | GRAB_RAM0 | R    | Oh    | Value in this field gets loaded from Z2_GRABRAM[1:0] when a read<br>is issued to address location of Z1_GRABRAM in OTP.<br>00 : Invalid. L0 RAM is inaccessible.<br>01 : Request to allocate L0 RAM to Zone1.<br>10 : Request to allocate L0 RAM to Zone2.                                            |  |

11 : Request to make L0 RAM Non-Secure.

### Table 1-149. Z2\_GRABRAMR Register Field Descriptions

### 1.8.5.11 Z2\_EXEONLYSECTR Register (offset = 1Eh) [reset = 0h]

Z2\_EXEONLYSECTR is shown in Figure 1-119 and described in Table 1-150.

Zone 2 Flash Execute\_Only Sector Register



LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-150. Z2\_EXEONLYSECTR Register Field Descriptions

| Bit   | Field         | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                |  |
|-------|---------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-16 | Reserved      | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                   |  |
| 15-10 | Reserved      | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                                   |  |
| 9     | EXEONLY_SECTJ | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[9:9] when a read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector J (only if it is allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector J (only if it is allocated to Zone2) |  |
| 8     | EXEONLY_SECTI | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[8:8] when a read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector I (only if it is allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector I (only if it is allocated to Zone2) |  |
| 7     | EXEONLY_SECTH | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[7:7] when a read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector H (only if it is allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector H (only if it is allocated to Zone2) |  |
| 6     | EXEONLY_SECTG | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[6:6] when a read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector G (only if it is allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector G (only if it is allocated to Zone2) |  |
| 5     | EXEONLY_SECTF | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[5:5] when a read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector F (only if it is allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector F (only if it is allocated to Zone2) |  |



| Bit | Field         | Туре | Reset | Description                                                                                                                                                                                                                                                                                                                                              |
|-----|---------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | EXEONLY_SECTE | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[4:4] when a<br>read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector E (only if it is<br>allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector E (only if it is<br>allocated to Zone2)                      |
| 3   | EXEONLY_SECTD | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[3:3] when a<br>read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector D (only if it is<br>allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector D (only if it is<br>allocated to Zone2)                      |
| 2   | EXEONLY_SECTC | R    | Oh    | <ul> <li>Value in this field gets loaded from Z2_EXEONLYSECT[2:2] when a read is issued to Z2_EXEONLYSECT address location in OTP.</li> <li>0: Execute-Only protection is enabled for Flash Sector C (only if it is allocated to Zone2)</li> <li>1: Execute-Only protection is disabled for Flash Sector C (only if it is allocated to Zone2)</li> </ul> |
| 1   | EXEONLY_SECTB | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[1:1] when a<br>read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector B (only if it is<br>allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector B (only if it is<br>allocated to Zone2)                      |
| 0   | EXEONLY_SECTA | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYSECT[0:0] when a<br>read is issued to Z2_EXEONLYSECT address location in OTP.<br>0 : Execute-Only protection is enabled for Flash Sector A (only if it is<br>allocated to Zone2)<br>1 : Execute-Only protection is disabled for Flash Sector A (only if it is<br>allocated to Zone2)                      |

### 1.8.5.12 Z2\_EXEONLYRAMR Register (offset = 20h) [reset = 0h]

Z2\_EXEONLYRAMR is shown in Figure 1-120 and described in Table 1-151.

Zone 2 RAM Execute\_Only Block Register

| Figure 1-120. 22_EXECULT RAMIN Register |      |       |     |              |              |              |              |
|-----------------------------------------|------|-------|-----|--------------|--------------|--------------|--------------|
| 31                                      | 30   | 29    | 28  | 27           | 26           | 25           | 24           |
|                                         |      |       | Res | served       |              |              |              |
|                                         |      |       | F   | R-Oh         |              |              |              |
| 23                                      | 22   | 21    | 20  | 19           | 18           | 17           | 16           |
|                                         |      |       | Res | served       |              |              |              |
|                                         |      |       | F   | R-Oh         |              |              |              |
| 15                                      | 14   | 13    | 12  | 11           | 10           | 9            | 8            |
|                                         |      |       | Res | served       |              |              |              |
| R-0h                                    |      |       |     |              |              |              |              |
| 7                                       | 6    | 5     | 4   | 3            | 2            | 1            | 0            |
|                                         | Rese | erved |     | EXEONLY_RAM3 | EXEONLY_RAM2 | EXEONLY_RAM1 | EXEONLY_RAM0 |
|                                         | R-   | 0h    |     | R-0h         | R-0h         | R-0h         | R-0h         |

### Figure 1-120. Z2\_EXEONLYRAMR Register

LEGEND: R/W = Read/Write; R = Read only; W1toCl = Write 1 to clear bit; -n = value after reset

### Table 1-151. Z2\_EXEONLYRAMR Register Field Descriptions

| Bit   | Field        | Туре | Reset | Description                                                                                                                                                                                                                                                                                                       |  |
|-------|--------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-16 | Reserved     | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                          |  |
| 15-4  | Reserved     | R    | 0h    | Reserved                                                                                                                                                                                                                                                                                                          |  |
| 3     | EXEONLY_RAM3 | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYRAM[3:3] when a<br>read is issued to Z2_EXEONLYRAM address location in OTP.<br>0 : Execute-Only protection is enabled for L3 RAM (only if it is<br>allocated to Zone2)<br>1 : Execute-Only protection is disabled for L3 RAM (only if it is<br>allocated to Zone2) |  |
| 2     | EXEONLY_RAM2 | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYRAM[2:2] when a<br>read is issued to Z2_EXEONLYRAM address location in OTP.<br>0 : Execute-Only protection is enabled for L2 RAM (only if it is<br>allocated to Zone2)<br>1 : Execute-Only protection is disabled for L2 RAM (only if it is<br>allocated to Zone2) |  |
| 1     | EXEONLY_RAM1 | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYRAM[1:1] when a read is issued to Z2_EXEONLYRAM address location in OTP.<br>0 : Execute-Only protection is enabled for L1 RAM (only if it is allocated to Zone2)<br>1 : Execute-Only protection is disabled for L1 RAM (only if it is allocated to Zone2)          |  |
| 0     | EXEONLY_RAM0 | R    | Oh    | Value in this field gets loaded from Z2_EXEONLYRAM[0:0] when a read is issued to Z2_EXEONLYRAM address location in OTP.<br>0 : Execute-Only protection is enabled for L0 RAM (only if it is allocated to Zone2)<br>1 : Execute-Only protection is disabled for L0 RAM (only if it is allocated to Zone2)          |  |



## **ROM Code and Peripheral Booting**

This chapter is applicable for the code and data stored in the on-chip boot ROM, Secure ROM and CLA Data ROM, on the TMS320x2805x processors. This includes all devices within this family.

The boot ROM is factory programmed with boot-loading software. Boot-mode signals (TRST and general purpose I/Os) are used to tell the bootloader software which mode to use on power-up. The boot ROM also contains standard math tables, such as SIN/COS waveforms, for use in IQ math related algorithms found in the  $C28x^{TM}$  IQMath Library - A Virtual Floating Point Engine (literature number SPRC087).

This chapter descibes the purpose and features of the bootloader as well as other contents of the device on-chip boot ROM and identifies where all of the information is located within that memory

### Topic

Page

| 2.1 | Boot ROM     | 207        |
|-----|--------------|------------|
| 2.2 | CLA DATA ROM | 254        |
| 2.3 | Secure ROM   | <b>256</b> |



### 2.1 Boot ROM

The boot ROM is an 12K x 16 block of read-only memory located at addresses 0x3F D000 - 0x3F FFFF.

The on-chip boot ROM is factory programmed with boot-load routines and math tables. These are for use with the C28x<sup>™</sup> IQMath Library - A Virtual Floating Point Engine (SPRC087). This document describes the following items:

- Bootloader functions
- Version number, release date and checksum
- Reset vector
- Illegal trap vector (ITRAP)
- CPU vector table (Used for test purposes only)
- IQmath Tables
- Selected IQmath functions
- Flash API library

Figure 2-1 shows the memory map of the on-chip boot ROM. The memory block is 8Kx16 in size and is located at 0x3F E000 - 0x3F FFFF in both program and data space.

| On Chip B       | Section Start         |            |  |
|-----------------|-----------------------|------------|--|
| Data Space      | Data Space Prog Space |            |  |
|                 |                       | 0x3F D000  |  |
| Rese            | erved                 |            |  |
| Sin/            | 0                     | 0x3F DB52  |  |
| 510/0           | LOS                   | _          |  |
| Normalize       | d Inverse             |            |  |
| Normalized S    | quare Root            |            |  |
| Normalize       | ed Actan              |            |  |
| Rounding and    | _                     |            |  |
| Ex              |                       |            |  |
| Asin//          | 0x03F E7D8            |            |  |
| IQmath Fu       | inctions              |            |  |
| Bootloader      | Functions             | 0x03F F2D2 |  |
|                 | 4.51                  | 0x3F F7D2  |  |
| Flash           | API                   | 0x3FFEB9   |  |
| ROM API         | ROM API TABLE         |            |  |
| DOWN            | · · · · · · · ·       | 0x3FFFBA   |  |
| ROM V<br>ROM Ch |                       | 0x3F FFC0  |  |
|                 | Reset Vector          |            |  |
| CPU Vecto       |                       |            |  |
| (64 x           | 16)                   | 0x3F FFFF  |  |

#### Figure 2-1. Memory Map of On-Chip ROM



### 2.1.1 On-Chip Boot ROM IQmath Tables

The fixed-point math tables and functions included in the boot ROM are used by the Texas Instruments<sup>TM</sup> *C28x<sup>TM</sup> IQMath Library - A Virtual Floating Point Engine* (<u>SPRC087</u>). The 28x IQmath Library is a collection of highly optimized and high precision mathematical functions for C/C++ programmers to seamlessly port a floating-point algorithm into fixed-point code on TMS320C28x devices.

These routines are typically used in computational-intensive real-time applications where optimal execution speed and high accuracy is critical. By using these routines you can achieve execution speeds that are considerably faster than equivalent code written in standard ANSI C language. In addition, by providing ready-to-use high precision functions, the TI IQmath Library can shorten significantly your DSP application development time.

IQmath library accesses the tables through the IQmathTables and the IQmathTablesRam linker sections. Both of these sections are completely included in the boot ROM. If you do not wish to load a copy of these tables already included in the ROM into the device, use the boot ROM memory addresses and label the sections as "NOLOAD" as shown in Example 2-1. This facilitates referencing the look-up tables without actually loading the section to the target.

The preferred alternative to using the linker command file is to use the IQmath boot ROM symbol library. If this library is linked in the project before the IQmath library, and the linker -priority option is used, then any math tables and IQmath functions within the boot ROM will be used first. Refer to the IQMath Library documentation for more information.

### Example 2-1. Linker Command File to Access IQ Tables

```
MEMORY
{
   PAGE 0 :
  IQTABLES : origin = 0x3FE000, length = 0x000b50
  IOTABLES2 : origin = 0x3FEB50, length = 0x00008c
  IQTABLES3 : origin = 0x3FEBDC, length = 0x0000AA
}
SECTIONS
{
   . . .
   IQmathTables : load = IQTABLES, type = NOLOAD, PAGE = 0
   IQmathTables2 > IQTABLES2, type = NOLOAD, PAGE = 0
   {
       IQmath.lib<IQNexpTable.obj> (IQmathTablesRam)
   }
       IQmathTables3 : load = IQTABLES3, PAGE = 0
   {
       IQNasinTable.obj (IQmathTablesRam)
   }
   . . .
}
```

The following math tables are included in the Boot ROM:

### Sine/Cosine Table, IQ Math Table

- Table size: 1282 words
- Q format: Q30
- Contents: 32-bit samples for one and a quarter period sine wave

This is useful for accurate sine wave generation and 32-bit FFTs. This can also be used for 16-bit math, just skip over every second value.

- Normalized Inverse Table, IQ Math Table
  - Table size: 528 words
  - Q format: Q29



- Contents: 32-bit normalized inverse samples plus saturation limits

This table is used as an initial estimate in the Newton-Raphson inverse algorithm. By using a more accurate estimate the convergence is quicker and hence cycle time is faster.

### • Normalized Square Root Table, IQ Math Table

- Table size: 274 words
- Q format: Q30
- Contents: 32-bit normalized inverse square root samples plus saturation

This table is used as an initial estimate in the Newton-Raphson square-root algorithm. By using a more accurate estimate the convergence is quicker and hence cycle time is faster.

### Normalized Arctan Table, IQ Math Table

- Table size: 452 words
- Q format: Q30
- Contents 32-bit second order coefficients for line of best fit plus normalization table

This table is used as an initial estimate in the Arctan iterative algorithm. By using a more accurate estimate the convergence is quicker and hence cycle time is faster.

### • Rounding and Saturation Table, IQ Math Table

- Table size: 360 words
- Q format: Q30
- Contents: 32-bit rounding and saturation limits for various Q values

### Exp Min/Max Table, IQMath Table

- Table size: 120 words
- Q format: Q1 Q30
- Contents: 32-bit Min and Max values for each Q value

### • Exp Coefficient Table, IQMath Table

- Table size: 20 words
- Q format: Q31
- Contents: 32-bit coefficients for calculating exp (X) using a taylor series

### • Inverse Sin/Cos Table, IQ Math Table

- Table size: 85 x 16
- Q format: Q29
- Contents: Coefficient table to calculate the formula  $f(x) = c4^{*}x^{4} + c3^{*}x^{3} + c2^{*}x^{2} + c1^{*}x + c0$ .

### 2.1.2 On-Chip Boot ROM IQmath Functions

The following IQmath functions are included in the Boot ROM:

- IQNatan2 N= 15, 20, 24, 29
- IQNcos N= 15, 20, 24, 29
- IQNdiv N= 15, 20, 24, 29
- IQisqrt N= 15, 20, 24, 29
- IQNmag N= 15, 20, 24, 29
- IQNsin N= 15, 20, 24, 29
- IQNsqrt N= 15, 20, 24, 29

These functions can be accessed using the IQmath boot ROM symbol library included with the boot ROM source. If this library is linked in the project before the IQmath library, and the linker -priority option is used, then any math tables and IQmath functions within the boot ROM will be used first. Refer to the IQMath Library documentation for more information.

### 2.1.3 On-Chip Flash API

The boot ROM contains the API to program and erase the flash. This flash API can be accessed using the boot ROM flash API symbol library released with the boot ROM source. Refer to the device Flash API Library documentation for information on how to use the symbol library.

### 2.1.4 CPU Vector Table

A CPU vector table resides in boot ROM memory from address 0x3F E000 - 0x3F FFFF. This vector table is active after reset when VMAP = 1, ENPIE = 0 (PIE vector table disabled).





- A The VMAP bit is located in Status Register 1 (ST1). VMAP is always 1 on reset. It can be changed after reset by software, however the normal operating mode will be to leave VMAP = 1.
- B The ENPIE bit is located in the PIECTRL register. The default state of this bit at reset is 0, which disables the Peripheral Interrupt Expansion block (PIE).

The only vector that will normally be handled from the internal boot ROM memory is the reset vector located at 0x3F FFC0. The reset vector is factory programmed to point to the InitBoot function stored in the boot ROM. This function starts the boot load process. A series of checking operations is performed on TRST and General-Purpose I/O (GPIO I/O) pins to determine which boot mode to use. This boot mode selection is described in Section 2.1.5.9 of this document.

The remaining vectors in the boot ROM are not used during normal operation. After the boot process is complete, you should initialize the Peripheral Interrupt Expansion (PIE) vector table and enable the PIE block. From that point on, all vectors, except reset, will be fetched from the PIE module and not the CPU vector table shown in Table 2-1.

For TI silicon debug and test purposes the vectors located in the boot ROM memory point to locations in the M0 SARAM block as described in Table 2-1. During silicon debug, you can program the specified locations in M0 with branch instructions to catch any vectors fetched from boot ROM. This is not required for normal device operation.

| ww | w.t | i.co | om |
|----|-----|------|----|
|    |     |      |    |

### Table 2-1. Vector Locations

| Vector  | Location in<br>Boot ROM | Contents<br>(i.e., points to) | Vector   | Location in<br>Boot ROM | Contents<br>(i.e., points to) |
|---------|-------------------------|-------------------------------|----------|-------------------------|-------------------------------|
| RESET   | 0x3F FFC0               | InitBoot                      | RTOSINT  | 0x3F FFE0               | 0x00 0060                     |
| INT1    | 0x3F FFC2               | 0x00 0042                     | Reserved | 0x3F FFE2               | 0x00 0062                     |
| INT2    | 0x3F FFC4               | 0x00 0044                     | NMI      | 0x3F FFE4               | 0x00 0064                     |
| INT3    | 0x3F FFC6               | 0x00 0046                     | ILLEGAL  | 0x3F FFE6               | ITRAPIsr                      |
| INT4    | 0x3F FFC8               | 0x00 0048                     | USER1    | 0x3F FFE8               | 0x00 0068                     |
| INT5    | 0x3F FFCA               | 0x00 004A                     | USER2    | 0x3F FFEA               | 0x00 006A                     |
| INT6    | 0x3F FFCC               | 0x00 004C                     | USER3    | 0x3F FFEC               | 0x00 006C                     |
| INT7    | 0x3F FFCE               | 0x00 004E                     | USER4    | 0x3F FFEE               | 0x00 006E                     |
| INT8    | 0x3F FFD0               | 0x00 0050                     | USER5    | 0x3F FFF0               | 0x00 0070                     |
| INT9    | 0x3F FFD2               | 0x00 0052                     | USER6    | 0x3F FFF2               | 0x00 0072                     |
| INT10   | 0x3F FFD4               | 0x00 0054                     | USER7    | 0x3F FFF4               | 0x00 0074                     |
| INT11   | 0x3F FFD6               | 0x00 0056                     | USER8    | 0x3F FFF6               | 0x00 0076                     |
| INT12   | 0x3F FFD8               | 0x00 0058                     | USER9    | 0x3F FFF8               | 0x00 0078                     |
| INT13   | 0x3F FFDA               | 0x00 005A                     | USER10   | 0x3F FFFA               | 0x00 007A                     |
| INT14   | 0x3F FFDC               | 0x00 005C                     | USER11   | 0x3F FFFC               | 0x00 007C                     |
| DLOGINT | 0x3F FFDE               | 0x00 005E                     | USER12   | 0x3F FFFE               | 0x00 007E                     |



### 2.1.5 Bootloader Features

This section describes in detail the boot mode selection process, as well as the specifics of the bootloader operation.

#### 2.1.5.1 Bootloader Functional Operation

The bootloader uses the state of TRST and two GPIO signals to determine which boot mode to use. The boot mode selection process and the specifics of each bootloader are described in the remainder of this document. Figure 2-3 shows the basic bootloader flow:



Texas

STRUMENTS



The reset vector in boot ROM redirects program execution to the InitBoot function. After performing device initialization the bootloader will check the state of the TRST pin to determine if an emulation pod is connected.

### • Emulation Boot (Emulation Pod is connected and TRST = 1)

In emulation boot, the boot ROM will check two SARAM locations called EMU\_KEY and EMU\_BMODE for a boot mode. If the contents of either location are invalid, then the "wait" boot mode is used. All boot mode options can be accessed by modifying the value of EMU\_BMODE through the debugger when performing an emulation boot.

### • Stand-alone Boot (TRST = 0)

If the device is in stand-alone boot mode, then the state of two GPIO pins are used to determine which boot mode execute. Options include: GetMode, wait, SCI, and parallel I/O. Each of the modes is described in detail in Table 2-4. The GetMode option by default boots to flash but can be customized by programming the BOOTMODE register in OTP mode to select another bootloader.

Note that on this device there are two BOOTMODE registers (Z1\_BOOTMODE and Z2\_BOOTMODE); one for each user OTP zone. By default, the boot ROM in GetMode function reads Z1\_BOOTMODE; if there is no valid OTP\_KEY present in that register, boot ROM will read Z2\_BOOTMODE register. Decoding of the final boot mode in the GetMode() function is explained further below in this document. These boot modes mentioned here are discussed in detail in Section 2.1.5.9.

After the selection process and if the required boot loading is complete, the processor will continue execution at an entry point determined by the boot mode selected. If a bootloader was called, then the input stream loaded by the peripheral determines this entry address. This data stream is described in Section 2.1.5.11. If, instead, you choose to boot directly to Flash or SARAM mode, the entry address is predefined for each of these memory blocks.

The following sections discuss in detail the different boot modes available and the process used for loading data code into the device.

### 2.1.5.2 Bootloader Device Configuration

At reset, any 28x<sup>™</sup> CPU-based device is in 27x<sup>™</sup> object-compatible mode. It is up to the application to place the device in the proper operating mode before execution proceeds.

On this device, when booting from the internal boot ROM, the device is configured for 28x operating mode by the boot ROM software. The user is responsible for any additional configuration required.

For example, if your application includes C2xLP<sup>™</sup> source, then you are responsible for configuring the device for C2xLP source compatibility prior to execution of code generated from C2xLP source.

The configuration required for each operating mode is summarized in Table 2-2.

|                        | C27x Mode (Reset) | 28x Mode | C2xLP Source<br>Compatible Mode |
|------------------------|-------------------|----------|---------------------------------|
| OBJMODE                | 0                 | 1        | 1                               |
| AMODE                  | 0                 | 0        | 1                               |
| PAGE0                  | 0                 | 0        | 0                               |
| M0M1MAP <sup>(1)</sup> | 1                 | 1        | 1                               |
| Other Settings         |                   |          | SXM = 1, C = 1, SPM = 0         |

### Table 2-2. Configuration for Device Modes

<sup>(1)</sup> Normally for C27x compatibility, the M0M1MAP would be 0. On these devices, however, it is tied off high internally; therefore, at reset, M0M1MAP is always configured for 28x mode.

### 2.1.5.3 PLL Multiplier and DIVSEL Selection

The boot ROM changes the PLL multiplier (PLLCR) and divider (PLLSTS[DIVSEL]) bits as follows:

#### All boot modes:

PLLCR is not modified. PLLSTS[DIVSEL] is set to 3 for SYSCLKOUT = CLKIN/1. This increases the speed of the loaders.

- NOTE: The PLL multiplier (PLLSTS) and divider (PLLSTS[DIVSEL]) are not affected by a reset from the debugger. Therefore, a boot that is initialized from a reset from Code Composer Studio<sup>™</sup> may be at a different speed than booting by pulling the external reset line (XRS) low.
- **NOTE:** The reset value of PLLSTS[DIVSEL] is 0. This configures the device for SYSCLKOUT = CLKIN/4. The boot ROM will change this to SYSCLKOUT = CLKIN/1 to improve performance of the loaders. PLLSTS[DIVSEL] is left in this state when the boot ROM exits and it is up to the application to change it before configuring the PLLCR register.
- **NOTE:** The boot ROM leaves PLLSTS[DIVSEL] in the CLKIN/1 state when the boot ROM exits. This is not a valid configuration if the PLL is used; therefore the application must change it before configuring the PLLCR register.

### 2.1.5.4 Watchdog Module

When branching directly to Flash or M0 single-access RAM (SARAM), the watchdog is not touched. In the other boot modes, the watchdog is disabled before booting and then re-enabled and cleared before branching to the final destination address. If an incorrect key value is passed to the loader, the watchdog will be enabled and the device will boot to flash.

### 2.1.5.5 Taking an ITRAP Interrupt

If an illegal opcode is fetched, the device will take an ITRAP (illegal trap) interrupt. During the boot process, the interrupt vector used by the ITRAP is within the CPU vector table of the boot ROM. The ITRAP vector points to an interrupt service routine (ISR) within the boot ROM named ITRAPIsr(). This interrupt service routine attempts to enable the watchdog and then loops forever until the processor is reset. This ISR will be used for any ITRAP until the user's application initializes and enables the peripheral interrupt expansion (PIE) block. Once the PIE is enabled, the ITRAP vector located within the PIE vector table will be used.



### 2.1.5.6 Internal Pullup Resisters

Each GPIO pin has an internal pullup resistor that can be enabled or disabled in software. The pins that are read by the boot mode selection code to determine the boot mode selection have pull-ups enabled after reset by default. In noisy conditions, it is still recommended that you configure each of the boot mode selection pins externally.

The peripheral bootloaders all enable the pullup resistors for the pins that are used for control and data transfer. The bootloader leaves the resistors enabled for these pins when it exits. For example, the SCI-A bootloader enables the pullup resistors on the SCITXA and SCIRXA pins. It is your responsibility to disable them, if desired, after the bootloader exits.

### 2.1.5.7 PIE Configuration

The boot modes do not enable the PIE. It is left in its default state, which is disabled.

The boot ROM does, however, use the first six locations within the PIE vector table for emulation boot mode information and Flash API variables. These locations are not used by the PIE itself and not used by typical applications.

**NOTE:** If you are porting code from another 28x processor, check to see if the code initializes the first six locations in the PIE vector table to some default value. If it does, then consider modifying the code to not write to these locations so the EMU boot mode will not be over written during debug. Refer to the device header files and peripheral examples.

### 2.1.5.8 Reserved Memory

The M0 memory block address range 0x0002 - 0x004E is reserved for the stack and .ebss code sections during the boot-load process. If code is bootloaded into this region there is no error checking to prevent it from corrupting the boot ROM stack. Address 0x0000-0x0001 is the boot to M0 entry point. This should be loaded with a branch instruction to the start of the main application when using boot-to-SARAM mode.





Boot ROM loaders on older C28x devices had the stack in M1 memory.

**NOTE:** If code or data is bootloaded into the address range address range 0x0002 - 0x004E there is no error checking to prevent it from corrupting the boot ROM stack.



Boot ROM

In addition, the first six locations of the PIE vector table are used by the boot ROM. These locations are not used by the PIE itself and not used by typical applications. These locations are used as SARAM by the boot ROM and will not effect the behavior of the PIE. **Note:** Some example code from previous devices may initialize these locations. This will overwrite any boot mode you have populated. These locations are:

### Table 2-3. PIE Vector SARAM Locations Used by the Boot ROM

| Location    | Name                 | Note                    |
|-------------|----------------------|-------------------------|
| 0x0D00 x 16 | EMU_KEY              | Used for emulation boot |
| 0x0D01 x 16 | EMU_BMODE            | Used for emulation boot |
| 0x0D02 x 32 | Flash_CPUScaleFactor | Used by the flash API   |
| 0x0D04 x 32 | Flash_CallbackPtr    | Used by the flash API   |

### 2.1.5.9 Bootloader Modes

To accommodate different system requirements, the boot ROM offers a variety of boot modes. This section describes the different boot modes and gives brief summary of their functional operation. The states of TRST and two GPIO pins are used to determine the desired boot mode as shown in Table 2-4.

|          | GPIO37 TDO | GPIO34<br>CMP2OUT | TRST |                |
|----------|------------|-------------------|------|----------------|
| Mode EMU | Х          | x                 | 1    | Emulation Boot |
| Mode 0   | 0          | 0                 | 0    | Parallel I/O   |
| Mode 1   | 0          | 1                 | 0    | SCI            |
| Mode 2   | 1          | 0                 | 0    | Wait           |
| Mode 3   | 1          | 1                 | 0    | GetMode        |

Table 2-4. Boot Mode Selection

**NOTE:** The default behavior of the GetMode option on unprogrammed devices is to boot to flash. This behavior can be changed by programming the BOOTMODE register in OTP mode. In addition, if these locations are used by an application, then GetMode will jump to flash as long as OTP\_KEY != 0x55AA and/or OTP\_BMODE is not a valid value.

Figure 2-5 shows an overview of the boot process. Each step is described in greater detail in following sections.

**NOTE:** This device does not support the hardware wait-in-reset mode that is available on other C2000 parts. The "wait" boot mode can be used to emulate a wait-in-reset mode. The "wait" mode is very important for debugging devices with the CSM password programmed (i.e., secured). When the device is powered up, the CPU will start running and may execute an instruction that performs an access to a protected emulation code security logic (ECSL) area. If this happens, the ECSL will trip and cause the emulator connection to be cut. The "wait" mode keeps this from happening by looping within the boot ROM until an emulator is connected.







The following boot mode is used when an emulator is connected:

## Emulation Boot

In this case an emulation pod is connected to the device (TRST = 1) and the boot ROM derives the boot mode from the first two locations in the PIE vector table. These locations, called EMU\_KEY and EMU\_BMODE, are not used by the PIE module and not typically used by applications. Valid values for EMU\_KEY and EMU\_BMODE are shown in Table 2-5.

An EMU\_KEY value of 0x55AA indicates the EMU\_BMODE is valid. An invalid key or invalid mode will result in calling the wait boot mode. EMU\_BMODE and EMU\_KEY are automatically populated by the boot ROM when powering up with TRST = 0. EMU\_BMODE can also be initialized manually through the debugger.

| Address | Name      |                                     | Value                                                    |  |
|---------|-----------|-------------------------------------|----------------------------------------------------------|--|
|         |           | if TRST == 1 and EMU_KEY == 0x55AA, |                                                          |  |
| 0x0D00  | EMU KEY   | then ch                             | eck EMU_BMODE for the boot mode,                         |  |
| 0,00000 | EMO_RET   |                                     | else { Invalid EMU_KEY                                   |  |
|         |           |                                     | Boot mode = WAIT_BOOT }                                  |  |
|         |           | 0x0000                              | Boot mode = PARALLEL_BOOT                                |  |
|         |           | 0x0001                              | Boot mode = SCI_BOOT                                     |  |
|         |           | 0x0002                              | Boot mode = WAIT_BOOT                                    |  |
|         |           | 0x0003                              | Boot mode = GET_BOOT<br>(GetMode from OTP_KEY/OTP_BMODE) |  |
| 0x0D01  | EMU_BMODE | 0x0004                              | Boot mode = SPI_BOOT                                     |  |
|         | _         | 0x0005                              | Boot mode = I2C_BOOT                                     |  |
|         |           | 0x0007                              | Boot mode = CAN_BOOT                                     |  |
|         |           | 0x000A                              | Boot mode = RAM_BOOT                                     |  |
|         |           | 0x000B                              | Boot mode = FLASH_BOOT                                   |  |
|         |           | Other                               | Boot mode = WAIT_BOOT                                    |  |

# Table 2-5. Valid EMU\_KEY and EMU\_BMODE Values

Table 2-8 shows the expanded emulation boot mode table.

Here are two examples of an emulation boot:

# Example 2-2. Debug an application that loads through the SCI at boot.

To debug an application that loads through the SCI at boot, follow these steps:

- Configure the pins for mode 1, SCI, and initiate a power-on-reset.
- The boot ROM will detect  $\overline{\text{TRST}} = 0$  and will use the two pins to determine SCI boot.
- The boot ROM populates EMU\_KEY with 0x55AA and EMU\_BMODE with SCI\_BOOT.
- The boot ROM sits in the SCI loader waiting for data.
- Connect the debugger. TRST will go high.
- Perform a debugger reset and run. The bootloader will use the EMU\_BMODE and boot to SCI.

# TEXAS INSTRUMENTS

#### www.ti.com

# Example 2-3. You want to connect your emulator, but do not want application code to start executing before the emulator connects.

To connect your emulator, but keep application code from executing before the emulator connects:

- Configure GPIO37 and GPIO34 pins for mode 2, WAIT, and initiate a power-on-reset.
- The boot ROM will detect TRST = 0 and will use the two pins to determine wait boot.
- The boot ROM populates EMU\_KEY with 0x55AA and EMU\_BMODE with WAIT\_BOOT.
- The boot ROM sits in the wait routine.
- Connect the debugger; TRST will go high.
- Modify the EMU\_BMODE via the debugger to boot to FLASH or other desired boot mode.
- Perform a debugger reset and run. The boot loader will use the EMU\_BMODE and boot to the desired loader or location.
  - **NOTE:** The behavior of emulators with regards to TRST differs. Some emulators pull TRST high only when Code Composer Studio is in a connected state. For these emulators, if CCS is disconnected TRST will return to a low state. With CCS disconnected, GPIO34 and GPIO37 will be used to determine the boot mode. For these emulators, this is true even if the emulator pod is physically connected.

Some emulators pull TRST high when CCS connects and leave it high as long as the power sense pin is active. TRST will remain high even after CCS disconnects. For these emulators, the EMU mode stored in RAM will be used unless the target is power cycled, causing the state of TRST to reset back to a low state.

The following boot modes are invoked by the state of the boot mode pins if an emulator is not connected:

• Wait

This device does not support the hardware wait-in-reset mode that is available on other C2000 parts. The "wait" boot mode can be used to emulate a wait-in-reset mode. The "wait" mode is very important for debugging devices with the CSM password programmed (i.e., secured). When the device is powered up, the CPU will start running and may execute an instruction that performs an access to a emulation code security logic (ECSL) protected area. If this happens, the ECSL will trip and cause the emulator connection to be cut. The "wait" mode keeps this from happening by looping within the boot ROM until an emulator is connected

This mode writes WAIT\_BOOT to EMU\_BMODE. Once the emulator is connected you can then manually populate the EMU\_BMODE with the appropriate boot mode for the debug session.

SCI

In this mode, the boot ROM will load code to be executed into on-chip memory via the SCI-A port. When invoked as a stand-alone mode, the boot ROM writes SCI\_BOOT to EMU\_BMODE.

# Parallel I/O 8-bit

The parallel I/O boot mode is typically used only by production flash programmers.

GetMode

The GetMode option uses two values within the BOOTMODE register to determine the boot mode. On an un-programmed device, this mode will always boot to flash. On a programmed device, you can choose to program these locations to change the behavior. If either of these locations is not an expected value, then boot to flash will be used.

The values used by the Get\_Mode() function are shown in Table 2-6 and the flowchart is illustrated in Figure 2-6.

#### Table 2-6. OTP Values for GetMode

| Name      | Value                                                        | Value                                                         |  |  |  |
|-----------|--------------------------------------------------------------|---------------------------------------------------------------|--|--|--|
|           | GetMode will b                                               | GetMode will be entered if one of the two conditions is true: |  |  |  |
|           | Case 1: TRST                                                 | == 0, GPIO34 == 1 and GPIO37 == 1                             |  |  |  |
|           | Case 2: TRST                                                 | == 1, EMU_KEY == 0x55AA and EMU_BMODE == GET_BOOT             |  |  |  |
| OTP_KEY   | GetMode first of                                             | GetMode first checks the value of OTP_KEY:                    |  |  |  |
|           | if OTP_KEY == 0x55AA, then check OTP_BMODE for the boot mode |                                                               |  |  |  |
|           | else { Invalid key: Boot mode = FLASH_BOOT }                 |                                                               |  |  |  |
|           | 0x0001                                                       | Boot mode = SCI_BOOT                                          |  |  |  |
|           | 0x0004                                                       | Boot mode = SPI_BOOT                                          |  |  |  |
| OTP_BMODE | 0x0005                                                       | Boot mode = I2C_BOOT                                          |  |  |  |
|           | 0x0007                                                       | Boot mode = CAN_BOOT                                          |  |  |  |
|           | Other                                                        | Boot mode = FLASH_BOOT                                        |  |  |  |



Figure 2-6. GetMode Flowchart

OTP\_KEY and OTP\_BMODE bits are available in Zx-BOOTMODE registers and the definition of Zx-BOOTMODE.OTP\_KEY and Zx-BOOTMODE.OTP\_BMODE are shown in Table 2-7. The device has two OTP zones (Z1-BOOTMODE and Z2-BOOTMODE) and so there are two OTP boot mode registers as defined in the *Security Module* chapter.

| Table 2-7. | <b>Zx-BOOTMODE</b> | <b>Register Bit</b> | Definition |
|------------|--------------------|---------------------|------------|
|            |                    | Regiotor Bit        | Donning    |

| Bit(s)   | Name      | Туре | Reset | Description                                                                                                                                                        |
|----------|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:00    | OTP_KEY   | R    | 0     | The field gets loaded automatically with the Zx USER<br>OTP's BOOTMODE[15:0] content when the device<br>reads the BOOTMODE address location in the Zx<br>USER OTP  |
| 31:16:00 | OTP_BMODE | R    | 0     | The field gets loaded automatically with the Zx USER<br>OTP's BOOTMODE[31:16] content when the device<br>reads the BOOTMODE address location in the Zx<br>USER OTP |

The following boot modes shown in are available through the emulation boot option. Some are also available as a programmed get mode option.

## Jump to M0 SARAM

This mode is only available in emulation boot. The boot ROM software configures the device for 28x operation and branches directly to address 0X000000. This is the first address in the M0 memory block.

#### • Jump to branch instruction in flash memory.

Jump to flash is the default behavior of the Get Mode boot option. Jump to flash is also available as an emulation boot option.

In this mode, the boot ROM software configures the device for 28x operation and branches directly to location 0x3F 7FFE. You are required to have previously programmed a branch instruction at location 0x3F 7FFE that will redirect code execution to either a custom boot-loader or the application code.

#### SPI EEPROM or Flash boot mode (SPI-A)

Jump to SPI is available in stand-alone mode as a programmed Get Mode option. That is, to configure a device for SPI boot in stand-alone mode, the OTP\_KEY and OTP\_BMODE locations must be programmed for SPI\_BOOT and the boot mode pins configured for the Get Mode boot option.

SCI boot is also available as an emulation boot option.

In this mode, the boot ROM will load code and data into on-chip memory from an external SPI EEPROM or SPI flash via the SPI-A port.

## • I2C-A boot mode (I2C-A)

Jump to I2C is available in stand-alone mode as a programmed Get mode option. That is, to configure a device for I2C boot in stand-alone mode, the OTP\_KEY and OTP\_BMODE locations must be programmed for I2C\_BOOT and the boot mode pins configured for the Get Mode boot option.

I2C boot is also available as an emulation boot option.

In this mode, the boot ROM will load code and data into on-chip memory from an external serial EEPROM or flash at address 0x50 on the I2C-A bus.

#### eCAN-A boot mode (eCAN-A)

Jump to eCAN is available in stand-alone mode as a programmed Get mode option. That is, to configure a device for eCAN boot in stand-alone mode, the OTP\_KEY and OTP\_BMODE locations must be programmed for CAN\_BOOT and the boot mode pins configured for the Get Mode boot option. eCAN boot is also available as an emulation boot option. In this mode, the eCAN-A peripheral is used to transfer data and code into the on-chip memory using eCAN-A mailbox 1. The transfer is an 8-bit data stream with two 8-bit values being transferred during each communication.

| TRST | GPIO37<br>TDO    | GPIO34 | EMU<br>KEY<br>Read<br>from<br>0x0D00 | EMU<br>BMODE<br>Read<br>from<br>0x0D01 | OTP<br>KEY<br>Read<br>from<br>0x3D7BFE | OTP<br>BMODE<br>Read<br>from<br>0x3D7BFF | Boot Mode<br>Selected <sup>(1)</sup> | EMU<br>KEY<br>Written<br>to<br>0x0D00 | EMU<br>BMODE<br>Written<br>to<br>0x0D01 |
|------|------------------|--------|--------------------------------------|----------------------------------------|----------------------------------------|------------------------------------------|--------------------------------------|---------------------------------------|-----------------------------------------|
| 1    | x <sup>(2)</sup> | x      | !=0x55AA                             | х                                      | x                                      | x                                        | Wait                                 | -                                     | -                                       |

# Table 2-8. Emulation Boot modes (TRST = 1)

<sup>(1)</sup> Get Mode indicated the boot mode was derived from the values programmed in the OTP\_KEY and OTP\_BMODE of the Zx-BOOTMODE registers.

<sup>(2)</sup> x = don't care.

Boot ROM

| TRST | GPIO37 |        | EMU<br>KEY             | EMU<br>BMODE           | OTP<br>KEY               | OTP<br>BMODE             | Boot Mode               | EMU<br>KEY              | EMU<br>BMODE            |
|------|--------|--------|------------------------|------------------------|--------------------------|--------------------------|-------------------------|-------------------------|-------------------------|
|      | TDO    | GPIO34 | Read<br>from<br>0x0D00 | Read<br>from<br>0x0D01 | Read<br>from<br>0x3D7BFE | Read<br>from<br>0x3D7BFF | Selected <sup>(1)</sup> | Written<br>to<br>0x0D00 | Written<br>to<br>0x0D01 |
|      |        |        | 0x55AA                 | 0x0000                 | x                        | х                        | Parallel I/O            | -                       | -                       |
|      |        |        |                        | 0x0001                 | x                        | х                        | SCI                     | -                       | -                       |
|      |        |        |                        | 0x0002                 | х                        | х                        | Wait                    | -                       | -                       |
|      |        |        |                        | 0x0003                 | != 0x55AA                | х                        | GetMode: Flash          | -                       | -                       |
|      |        |        |                        |                        | 0X55AA                   | 0x0001                   | GetMode: SCI            | -                       | -                       |
|      |        |        |                        |                        |                          | 0x0003                   | GetMode: Flash          | -                       | -                       |
|      |        |        |                        |                        |                          | 0x0004                   | GetMode: SPI            | -                       | -                       |
|      |        |        |                        |                        |                          | 0x0005                   | GetMode: I2C            | -                       | -                       |
|      |        |        |                        |                        |                          | 0x0007                   | GetMode: CAN            | -                       | -                       |
|      |        |        |                        |                        |                          | Other                    | GetMode: Flash          | -                       | -                       |
|      |        |        |                        | 0x0004                 | x                        | x                        | SPI                     | -                       | -                       |
|      |        |        |                        | 0x0005                 | x                        | x                        | I2C                     | -                       | -                       |
|      |        |        |                        | 0x0007                 | x                        | x                        | CAN                     | -                       | -                       |
|      |        |        |                        | 0x000A                 | x                        | x                        | Boot to RAM             | -                       | -                       |
|      |        |        |                        | 0x000B                 | x                        | x                        | Boot to FLASH           | -                       | -                       |
|      |        |        |                        | Other                  | x                        | x                        | Wait                    | -                       | -                       |

## Table 2-9. Stand-Alone Boot Modes with (TRST = 0)

| TRST | GPIO37<br>TDO | GPIO34 | EMU<br>KEY<br>Read<br>from<br>0x0D00 | EMU<br>BMODE<br>Read<br>from<br>0x0D01 | OTP<br>KEY<br>Read<br>from<br>0x3D7BFE | OTP<br>BMODE<br>Read<br>from<br>0x3D7BFF | Boot Mode<br>Selected <sup>(1)</sup> | (2)<br>EMU<br>KEY<br>Written<br>to<br>0x0D00 | (2)<br>EMU<br>BMODE<br>Written<br>to<br>0x0D01 |
|------|---------------|--------|--------------------------------------|----------------------------------------|----------------------------------------|------------------------------------------|--------------------------------------|----------------------------------------------|------------------------------------------------|
| 0    | 0             | 0      | x <sup>(3)</sup>                     | х                                      | х                                      | х                                        | Parallel I/O                         | 0x55AA                                       | 0x0000                                         |
| 0    | 0             | 1      | х                                    | х                                      | x                                      | x                                        | SCI                                  | 0x55AA                                       | 0x0001                                         |
| 0    | 1             | 0      | х                                    | х                                      | x                                      | x                                        | Wait                                 | 0x55AA                                       | 0x0002                                         |
|      |               |        |                                      | !=0x55A/                               | !=0x55AA                               | x                                        | GetMode: Flash                       | _                                            |                                                |
|      |               |        |                                      |                                        |                                        | 0x0001                                   | GetMode: SCI                         |                                              |                                                |
|      |               |        |                                      |                                        |                                        | 0x0003                                   | GetMode: Flash                       |                                              |                                                |
| 0    | 1             | 1      | х                                    | x                                      | 0x55AA                                 | 0x0004                                   | GetMode: SPI                         | 0x55AA                                       | 0x0003                                         |
|      |               |        |                                      |                                        | UXSSAA                                 | 0x0005                                   | 05 GetMode: I2C                      |                                              |                                                |
|      |               |        |                                      |                                        |                                        | 0x0007                                   | GetMode: CAN                         |                                              |                                                |
|      |               |        |                                      |                                        |                                        | Other                                    | GetMode: Flash                       |                                              |                                                |

<sup>(1)</sup> Get Mode indicates the boot mode was derived from the values programmed in the OTP\_KEY and OTP\_BMODE of the Zx-BOOTMODE registers.

<sup>(2)</sup> The boot ROM will write this value to EMU\_KEY and EMU\_BMODE. This value can be used or overwritten by the user if a debugger is connected.

(3) x = don't care.

## 2.1.5.10 Device\_Cal

The Device\_cal() routine is programmed into TI reserved memory by the factory. The boot ROM automatically calls the Device\_cal() routine to calibrate the internal oscillators and ADC with device specific calibration data. During normal operation, this process occurs automatically and no action is required by the user.

If the boot ROM is bypassed by Code Composer Studio during the development process, then the calibration must be initialized by application. For working examples, see the system initialization in the device *Header Files and Peripheral Examples*.

**NOTE:** Failure to initialize these registers will cause the oscillators and ADC to function out of specification. The following three steps describe how to call the Device\_cal routine from an application.

Step 1: Create a pointer to the Device\_cal function as shown in Example 2-4. This #define is included in the Header Files and Peripheral Examples.

Step 2: Call the function pointed to by Device\_cal() as shown in Example 2-4. The ADC clocks must be enabled before making this call.

Example 2-4. Calling the Device\_cal() function

```
//Device call is a pointer to a function
//that begins at the address shown
# define Device_cal (void(*)(void))0x3D7C80
... ...
EALLOW;
SysCtrlRegs.PCLKCR0.bit.ADCENCLK = 1;
(*Device_cal)();
SysCtrlRegs.PCLKCR0.bit.ADCENCLK = 0;
EDIS;
.
```

# 2.1.5.11 Bootloader Data Stream Structure

The following two tables and associated examples show the structure of the data stream incoming to the bootloader. The basic structure is the same for all the bootloaders and is based on the C54x source data stream generated by the C54x hex utility. The C28x hex utility (hex2000.exe) has been updated to support this structure. The hex2000.exe utility is included with the C2000 code generation tools. All values in the data stream structure are in hex.

The first 16-bit word in the data stream is known as the key value. The key value is used to tell the bootloader the width of the incoming stream: 8 or 16 bits. Note that not all bootloaders will accept both 8 and 16-bit streams. Please refer to the detailed information on each loader for the valid data stream width. For an 8-bit data stream, the key value is 0x08AA and for a 16-bit stream it is 0x10AA. If a bootloader receives an invalid key value, then the load is aborted.

The next eight words are used to initialize register values or otherwise enhance the bootloader by passing values to it. If a bootloader does not use these values then they are reserved for future use and the bootloader simply reads the value and then discards it. Currently only the SPI and I2C and parallel XINTF bootloaders use these words to initialize registers.

The tenth and eleventh words comprise the 22-bit entry point address. This address is used to initialize the PC after the boot load is complete. This address is most likely the entry point of the program downloaded by the bootloader.

The twelfth word in the data stream is the size of the first data block to be transferred. The size of the block is defined for both 8-bit and 16-bit data stream formats as the number of 16-bit words in the block. For example, to transfer a block of 20 8-bit data values from an 8-bit data stream, the block size would be 0x000A to indicate 10 16-bit words.

The next two words tell the loader the destination address of the block of data. Following the size and address will be the 16-bit words that makeup that block of data.



Boot ROM

www.ti.com

This pattern of block size/destination address repeats for each block of data to be transferred. Once all the blocks have been transferred, a block size of 0x0000 signals to the loader that the transfer is complete. At this point the loader will return the entry point address to the calling routine which in turn will cleanup and exit. Execution will then continue at the entry point address as determined by the input data stream contents.

TEXAS INSTRUMENTS

#### www.ti.com

| Word | Contents                                                                                                                                                                     |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | 10AA (KeyValue for memory width = 16bits)                                                                                                                                    |
| 2    | Register initialization value or reserved for future use                                                                                                                     |
| 3    | Register initialization value or reserved for future use                                                                                                                     |
| 4    | Register initialization value or reserved for future use                                                                                                                     |
| 5    | Register initialization value or reserved for future use                                                                                                                     |
| 6    | Register initialization value or reserved for future use                                                                                                                     |
| 7    | Register initialization value or reserved for future use                                                                                                                     |
| 8    | Register initialization value or reserved for future use                                                                                                                     |
| 9    | Register initialization value or reserved for future use                                                                                                                     |
| 10   | Entry point PC[22:16]                                                                                                                                                        |
| 11   | Entry point PC[15:0]                                                                                                                                                         |
| 12   | Block size (number of words) of the first block of data to load. If the block size is 0, this indicates the enc<br>of the source program. Otherwise another section follows. |
| 13   | Destination address of first block Addr[31:16]                                                                                                                               |
| 14   | Destination address of first block Addr[15:0]                                                                                                                                |
| 15   | First word of the first block in the source being loaded                                                                                                                     |
|      |                                                                                                                                                                              |
|      |                                                                                                                                                                              |
| ·    | Last word of the first block of the source being loaded<br>Block size of the 2nd block to load.                                                                              |
| •    |                                                                                                                                                                              |
| •    | Destination address of second block Addr[31:16]                                                                                                                              |
| •    | Destination address of second block Addr[15:0]                                                                                                                               |
| •    | First word of the second block in the source being loaded                                                                                                                    |
| •    |                                                                                                                                                                              |
| •    | Last word of the second block of the source being loaded<br>Block size of the last block to load                                                                             |
| •    |                                                                                                                                                                              |
| ·    | Destination address of last block Addr[31:16]                                                                                                                                |
| •    | Destination address of last block Addr[15:0]                                                                                                                                 |
| •    | First word of the last block in the source being loaded                                                                                                                      |
|      |                                                                                                                                                                              |
| n    | Last word of the last block of the source being loaded                                                                                                                       |
| n+1  | Block size of 0000h - indicates end of the source program                                                                                                                    |



Boot ROM

www.ti.com

#### Example 2-5. Data Stream Structure 16-bit

```
10AA
                   ; 0x10AA 16-bit key value
0000 0000 0000 0000 ; 8 reserved words
0000 0000 0000 0000
003F 8000
                 ; 0x003F8000 EntryAddr, starting point after boot load completes
0005
                 ; 0x0005 - First block consists of 5 16-bit words
                  ; 0x003F9010 - First block will be loaded starting at 0x3F9010
003F 9010
0001 0002 0003 0004 ; Data loaded = 0x0001 0x0002 0x0003 0x0004 0x0005
0005
                   ; 0x0002 - 2nd block consists of 2 16-bit words
0002
003F 8000
                   ; 0x003F8000 - 2nd block will be loaded starting at 0x3F8000
                  ; Data loaded = 0x7700 0x7625
7700 7625
0000
                   ; 0x0000 - Size of 0 indicates end of data stream
After load has completed the following memory values will have been initialized as follows:
Location Value
0x3F9010
            0x0001
0x3F9011
            0x0002
0x3F9012
            0x0003
           0x0004
0x3F9013
0x3F9014
          0x0005
0x3F8000
          0x7700
0x3F8001
           0x7625
PC Begins execution at 0x3F8000
```

In 8-bit mode, the least significant byte (LSB) of the word is sent first followed by the most significant byte (MSB). For 32-bit values, such as a destination address, the most significant word (MSW) is loaded first, followed by the least significant word (LSW). The bootloaders take this into account when loading an 8-bit data stream.

TEXAS INSTRUMENTS

#### www.ti.com

Boot ROM

| Byte |     | Contents                                                                                                                                                                                                                                          |                                                           |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--|--|--|--|--|--|--|
|      |     | LSB (First Byte of 2)                                                                                                                                                                                                                             | MSB (Second Byte of 2)                                    |  |  |  |  |  |  |  |
| 1    | 2   | LSB: AA (KeyValue for memory width = 8 bits)                                                                                                                                                                                                      | MSB: 08h (KeyValue for memory width = 8 bits)             |  |  |  |  |  |  |  |
| 3    | 4   | LSB: Register initialization value or reserved                                                                                                                                                                                                    | MSB: Register initialization value or reserved            |  |  |  |  |  |  |  |
| 5    | 6   | LSB: Register initialization value or reserved                                                                                                                                                                                                    | MSB: Register initialization value or reserved            |  |  |  |  |  |  |  |
| 7    | 8   | LSB: Register initialization value or reserved                                                                                                                                                                                                    | MSB: Register initialization value or reserved            |  |  |  |  |  |  |  |
|      |     |                                                                                                                                                                                                                                                   |                                                           |  |  |  |  |  |  |  |
|      |     |                                                                                                                                                                                                                                                   |                                                           |  |  |  |  |  |  |  |
| 17   | 18  | LSB: Register initialization value or reserved                                                                                                                                                                                                    | MSB: Register initialization value or reserved            |  |  |  |  |  |  |  |
| 19   | 20  | LSB: Upper half of Entry point PC[23:16]                                                                                                                                                                                                          | MSB: Upper half of entry point PC[31:24] (Always 0x00)    |  |  |  |  |  |  |  |
| 21   | 22  | LSB: Lower half of Entry point PC[7:0]                                                                                                                                                                                                            | MSB: Lower half of Entry point PC[15:8]                   |  |  |  |  |  |  |  |
| 23   | 24  | LSB: Block size in words of the first block to load. If the block size is 0, this indicates the end of the source program. Otherwise another block follows. For example, a block size of 0x000A would indicate 10 words or 20 bytes in the block. | MSB: block size                                           |  |  |  |  |  |  |  |
| 25   | 26  | LSB: MSW destination address, first block Addr[23:16]                                                                                                                                                                                             | MSB: MSW destination address, first block Addr[31:24]     |  |  |  |  |  |  |  |
| 27   | 28  | LSB: LSW destination address, first block Addr[7:0]                                                                                                                                                                                               | MSB: LSW destination address, first block Addr[15:8]      |  |  |  |  |  |  |  |
| 29   | 30  | LSB: First word of the first block being loaded                                                                                                                                                                                                   | MSB: First word of the first block being loaded           |  |  |  |  |  |  |  |
|      |     |                                                                                                                                                                                                                                                   |                                                           |  |  |  |  |  |  |  |
|      |     | LSB: Last word of the first block to load                                                                                                                                                                                                         | MSB: Last word of the first block to load                 |  |  |  |  |  |  |  |
|      |     | LSB: Block size of the second block                                                                                                                                                                                                               | MSB: Block size of the second block                       |  |  |  |  |  |  |  |
|      |     | LSB: MSW destination address, second block Addr[23:16]                                                                                                                                                                                            | MSB: MSW destination address, second block<br>Addr[31:24] |  |  |  |  |  |  |  |
|      |     | LSB: LSW destination address, second block Addr[7:0]                                                                                                                                                                                              | MSB: LSW destination address, second block Addr[15:8]     |  |  |  |  |  |  |  |
|      |     | LSB: First word of the second block being loaded                                                                                                                                                                                                  | MSB: First word of the second block being loaded          |  |  |  |  |  |  |  |
|      |     |                                                                                                                                                                                                                                                   |                                                           |  |  |  |  |  |  |  |
|      |     |                                                                                                                                                                                                                                                   |                                                           |  |  |  |  |  |  |  |
|      |     | LSB: Last word of the second block                                                                                                                                                                                                                | MSB: Last word of the second block                        |  |  |  |  |  |  |  |
|      |     | LSB: Block size of the last block                                                                                                                                                                                                                 | MSB: Block size of the last block                         |  |  |  |  |  |  |  |
| •    |     | LSB: MSW of destination address of last block Addr[23:16]                                                                                                                                                                                         | MSB: MSW destination address, last block Addr[31:24]      |  |  |  |  |  |  |  |
| •    | •   | LSB: LSW destination address, last block Addr[7:0]                                                                                                                                                                                                | MSB: LSW destination address, last block Addr[15:8]       |  |  |  |  |  |  |  |
| ·    |     | LSB: First word of the last block being loaded                                                                                                                                                                                                    | MSB: First word of the last block being loaded            |  |  |  |  |  |  |  |
|      |     |                                                                                                                                                                                                                                                   |                                                           |  |  |  |  |  |  |  |
|      |     | LSB: Last word of the last block                                                                                                                                                                                                                  | MSB: Last word of the last block                          |  |  |  |  |  |  |  |
| n    | n+1 | LSB: 00h                                                                                                                                                                                                                                          | MSB: 00h - indicates the end of the source                |  |  |  |  |  |  |  |



Boot ROM

www.ti.com

#### Example 2-6. Data Stream Structure 8-bit

```
80 AA
              ; 0x08AA 8-bit key value
00 00 00 00
            ; 8 reserved words
00 00 00 00
00 00 00 00
00 00 00 00
3F 00 00 80
             ; 0x003F8000 EntryAddr, starting point after boot load completes
05 00
              ; 0x0005 - First block consists of 5 16-bit words
3F 00 10 90
             ; 0x003F9010 - First block will be loaded starting at 0x3F9010
             ; Data loaded = 0x0001 0x0002 0x0003 0x0004 0x0005
01 00
02 00
03 00
04 00
05 00
02 00
             ; 0x0002 - 2nd block consists of 2 16-bit words
3F 00 00 80
            ; 0x003F8000 - 2nd block will be loaded starting at 0x3F8000
00 77
             ; Data loaded = 0x7700 0x7625
25 76
00 00
             ; 0x0000 - Size of 0 indicates end of data stream
After load has completed the following memory values will have been initialized as follows:
Location Value
0x3F9010 0x0001
0x3F9011 0x0002
0x3F9012
          0x0003
0x3F9013
          0x0004
         0x0005
0x3F9014
0x3F8000
         0x7700
0x3F8001 0x7625
PC Begins execution at 0x3F8000
```

#### 2.1.5.12 Basic Transfer Procedure

Figure 2-7 illustrates the basic process a bootloader uses to determine whether 8-bit or 16-bit data stream has been selected, transfer that data, and start program execution. This process occurs after the bootloader finds the valid boot mode selected by the state of TRST and GPIO pins.

The loader first compares the first value sent by the host against the 16-bit key value of 0x10AA. If the value fetched does not match then the loader will read a second value. This value will be combined with the first value to form a word. This will then be checked against the 8-bit key value of 0x08AA. If the loader finds that the header does not match either the 8-bit or 16-bit key value, or if the value is not valid for the given boot mode then the load will abort.







8-bit and 16-bit transfers are not valid for all boot modes. If only one mode is valid, then this decision tree is skipped and the key value is only checked for correctness. See the info specific to a particular bootloader for any limitations. In 8-bit mode, the LSB of the 16-bit word is read first followed by the MSB.

## 2.1.5.13 InitBoot Assembly Routine

This section details the first routine called after reset by the boot ROM.

## 2.1.5.13.1 Waitboot Mode Check on Start-up

The boot ROM decodes bootmode as the first step in the boot process. If the Wait boot mode option is selected as per the table below, then boot ROM will not execute any further and loops forever with the watchdog timer enabled. If any other boot mode option is selected, then boot ROM continues to execute normally.

| TRSTn | GPIO37 | GPIO34 | EMU_KEY | EMU_BMODE | Boot Mode<br>Selected |
|-------|--------|--------|---------|-----------|-----------------------|
|       | TDO    |        | Read    | Read      |                       |
|       |        |        | 0x0D00  | 0x0D01    |                       |
| 0     | 1      | 0      | х       | x         | Wait                  |
| 1     | X      | Х      | 0x55AA  | 0x0002    | Wait                  |
| 1     | X      | Х      | !0x55AA | Х         | Wait                  |



Note that this is checked by boot ROM on start-up only, to see if WaitBoot mode is selected or not. If selected, boot ROM will wait in a loop without executing further. If not selected, boot ROM goes ahead with the execution of the rest of the boot process.

## 2.1.5.13.2 Bootload of TRIM Data from TI-OTP

On this device, VREGTRIM, BOR TRIM, and POR TRIM are loaded from TI-OTP on power-up. But before boot ROM loads the TRIM data from OTP, it has to make sure that flash is powered-up correctly and OTP is being read correctly. The boot ROM uses the proceedure below to make sure that flash is powered up correctly.

## 2.1.5.13.2.1 Boot ROM procedure to make sure flash is powered up correctly

# 2.1.5.13.2.1.1 128 bit OTP\_SIGNATURE\_CHECK

- Boot ROM reads pre-defined OTP locations and compares the values at the locations to a pre-defined OTP signature.
- The flash databus is 64 bits, so to make sure each data line is read for both a '0' and '1' value. Boot ROM checks two 64-bit locations from TI-OTP, and compares them with 0x5555\_5555\_5555\_and 0xAAA\_AAAA\_AAAA\_AAAA, respectively.
- If signature compare matches, then boot ROM knows that flash is powered up and it can then load OTP contents on to device registers and will continue to boot normally.
- If signature comparison match fails, then boot ROM will reset the device using the watchdog timer and coming out of reset, it is going to try reading OTP again.

# 2.1.5.13.2.1.2 Factory-specific data loaded from TI-OTP

Below are the contents of OTP that boot ROM is going to read and copy onto device registers. Refer to the *Gizmo Boot ROM Bridging* spec for details on OTP addresses.

| OTP contents read by boot ROM    | Address in OTP      |
|----------------------------------|---------------------|
| TRIM SIGNATURE_AT_START (64 bit) | 0x3D7FCC - 0x3D7FCF |
| VREG, BOR, POR TRIM              | 0x3D7FDF            |
| DC1                              | 0x3D7FD0-0x3D7FD1   |
| DC2                              | 0x3D7FD2-0x3D7FD3   |
| DC3                              | 0x3D7FD4-0x3D7FD5   |
| TRIM_SIGNATURE_AT_END (64 bit)   | 0x3D7FFE-0x3D7FFF   |



## 2.1.5.13.3 Init Boot Routine Flow Chart

The init boot routine flow chart is shown in Figure 2-8.

# Figure 2-8. Init Boot Routine Flow Chart



## 2.1.5.14 SelectBootMode Function

To determine the desired boot mode, the SelectBootMode function examines the state of TRST and two GPIO pins as shown in Table 2-4.

For a boot mode to be selected, the pins corresponding to the desired boot mode have to be pulled low or high until the selection process completes. Note that the state of the selection pins is not latched at reset; they are sampled some cycles later in the SelectBootMode function. The internal pullup resistors are enabled at reset for the boot mode selection pins. It is still suggested that the boot mode configuration be made externally to avoid the effect of any noise on these pins.



**NOTE:** The SelectBootMode routine disables the watchdog before calling the SCI, I2C, SPI, McBSP, or parallel bootloaders. The bootloaders do not service the watchdog and assume that it is disabled. Before exiting, the SelectBootMode routine will re-enable the watchdog and reset its timer.

If a bootloader is not going to be called, then the watchdog is left untouched.

When selecting a boot mode, the pins should be pulled high or low through a weak pulldown or weak pullup such that the device can drive them to a new state when required.

Figure 2-9. Overview of the SelectBootMode Function





#### 2.1.5.15 CopyData Function

Each of the bootloaders uses the same function, the CopyData() function, to copy data from the port to the device's SARAM. The CopyData() function uses a pointer to a GetWordData function that is initialized by each of the loaders to properly read data from that port. For example, when the SPI loader is evoked, the GetWordData function pointer is initialized to point to the SPI-specific SPI\_GetWordData function. Therefore, when the CopyData() function is called, the correct port is accessed. The flow of the CopyData function is shown in Figure 2-10.

**Note:** BlockSize must be less than 0xFFFF for correct operation of the CopyData function. This means the max possible value of BlockSize is 0xFFFE, not 0xFFFF.





## 2.1.5.16 SCI\_Boot Function

The SCI boot mode asynchronously transfers code from SCI-A to internal memory. This boot mode only supports an incoming 8-bit data stream and follows the same data flow as outlined in Example 2-6.

Figure 2-11. Overview of SCI Bootloader Operation



The SCI-A loader uses following pins:

- SCIRXDA on GPIO28
- SCITXDA on GPIO29



Boot ROM

www.ti.com

The device communicates with the external host device through communication through the SCI-A peripheral. The autobaud feature of the SCI port is used to lock baud rates with the host. For this reason the SCI loader is very flexible and you can use a number of different baud rates to communicate with the device.

After each data transfer, the device will echo back the 8-bit character received to the host. In this manner, the host can perform checks that each character was received by the device.

At higher baud rates, the slew rate of the incoming data bits can be effected by transceiver and connector performance. While normal serial communications may work well, this slew rate may limit reliable autobaud detection at higher baud rates (typically beyond 100k baud) and cause the auto-baud lock feature to fail. To avoid this, the following is recommended:

- 1. Achieve a baud-lock between the host and SCI bootloader using a lower baud rate.
- 2. Load the incoming application or custom loader at this lower baud rate.
- 3. The host may then handshake with the loaded device application to set the SCI baud rate register to the desired high baud rate.



Figure 2-12. Overview of SCI\_Boot Function



Boot ROM







# 2.1.5.17 Parallel\_Boot Function (GPIO)

The parallel general purpose I/O (GPIO) boot mode asynchronously transfers code from GPIO0 -GPIO5, GPIO30-GPIO31 to internal memory. Each value is 8 bits long and follows the same data flow as outlined in Section 2.1.5.11.





The parallel GPIO loader uses following pins:

- Data on GPIO[31,30,5:0]
- 28x control on GPIO26 (external pull-up resistor may be required)
- Host control on GPIO27 (external pull-up resistor required)

The device communicates with the external host device by polling/driving the GPIO27 and GPIO26 lines. An external pull-up resistor is required for GPIO27 because GPIO pins lack internal pull-up circuitry required to prevent the device from reading data prematurely. Depending on the system, an external pull-up may also be required on GPIO26. The handshake protocol shown in Figure 2-15 must be used to successfully transfer each word via GPIO [31,30,5:0]. This protocol is very robust and allows for a slower or faster host to communicate with the device.

Two consecutive 8-bit words are read to form a single 16-bit word. The most significant byte (MSB) is read first, followed by the least significant byte (LSB). In this case, data is read from GPIO[31,30,5:0].

The 8-bit data stream is shown in Table 2-12.

| Bytes |     | es GPIO[31,30,5:0] GPIO[31,30,5:0]<br>(Byte 1 of 2) (Byte 2 of 2) |    | Description                                                                        |  |  |
|-------|-----|-------------------------------------------------------------------|----|------------------------------------------------------------------------------------|--|--|
| 1     | 2   | AA                                                                | 08 | 0x08AA (KeyValue for memory width = 16bits)                                        |  |  |
| 3     | 4   | 00                                                                | 00 | 8 reserved words (words 2 - 9)                                                     |  |  |
|       |     |                                                                   |    |                                                                                    |  |  |
| 17    | 18  | 00                                                                | 00 | Last reserved word                                                                 |  |  |
| 19    | 20  | BB                                                                | 00 | Entry point PC[22:16]                                                              |  |  |
| 21    | 22  | DD                                                                | CC | Entry point PC[15:0] (PC = 0x00BBCCDD)                                             |  |  |
| 23    | 24  | NN                                                                | MM | Block size of the first block of data to load = 0xMMNN words                       |  |  |
| 25    | 26  | BB                                                                | AA | Destination address of first block Addr[31:16]                                     |  |  |
| 27    | 28  | DD                                                                | CC | Destination address of first block Addr[15:0] (Addr = 0xAABBCCDD)                  |  |  |
| 29    | 30  | BB                                                                | AA | First word of the first block in the source being loaded = 0xAABB                  |  |  |
| <br>  |     |                                                                   |    | <br>Data for this section.<br>                                                     |  |  |
|       |     | BB                                                                | AA | Last word of the first block of the source being loaded = 0xAABB                   |  |  |
|       |     | NN                                                                | MM | Block size of the 2nd block to load = 0xMMNN words                                 |  |  |
|       |     | BB                                                                | AA | Destination address of second block Addr[31:16]                                    |  |  |
|       |     | DD                                                                | CC | Destination address of second block Addr[15:0]                                     |  |  |
|       |     | BB                                                                | AA | First word of the second block in the source being loaded                          |  |  |
|       |     |                                                                   |    |                                                                                    |  |  |
| n     | n+1 | BB                                                                | AA | Last word of the last block of the source being loaded (More sections if required) |  |  |
| n+2   | n+3 | 00                                                                | 00 | Block size of 0000h - indicates end of the source program                          |  |  |

Table 2-12, Parallel GPIO Boot 8-Bit Data Stream

The device first signals the host that it is ready to begin data transfer by pulling the GPIO26 pin low. The host load then initiates the data transfer by pulling the GPIO27 pin low. The complete protocol is shown in the diagram below:



- 1. The device indicates it is ready to start receiving data by pulling the GPIO26 pin low.
- 2. The bootloader waits until the host puts data on GPIO [31,30,5:0]. The host signals to the device that data is ready by pulling the GPIO27 pin low.
- 3. The device reads the data and signals the host that the read is complete by pulling GPIO26 high.
- 4. The bootloader waits until the host acknowledges the device by pulling GPIO27 high.
- 5. The device again indicates it is ready for more data by pulling the GPIO26 pin low.

This process is repeated for each data value to be sent.

Figure 2-16 shows an overview of the Parallel GPIO bootloader flow.



www.ti.com







Figure 2-17 shows the transfer flow from the host side. The operating speed of the CPU and host are not critical in this mode as the host will wait for the device, and the device will in turn wait for the host. In this manner the protocol will work with both a host running faster and a host running slower than the 28x.





Figure 2-17. Parallel GPIO Mode - Host Transfer Flow

Figure 2-18 show the flow used to read a single word of data from the parallel port.

# 8-bit data stream

The 8-bit routine, shown in Figure 2-18, discards the upper 8 bits of the first read from the port and treats the lower 8 bits masked with GPIO31 in bit position 7 and GPIO30 in bit position 6 as the least significant byte (LSB) of the word to be fetched. The routine will then perform a second read to fetch the most significant byte (MSB). It then combines the MSB and LSB into a single 16-bit value to be passed back to the calling routine.







#### 2.1.5.18 SPI\_Boot Function

The SPI loader expects an SPI-compatible 16-bit or 24-bit addressable serial EEPROM or serial flash device to be present on the SPI-A pins as indicated in Figure 2-19. The SPI bootloader supports an 8-bit data stream. It does not support a 16-bit data stream.

| 28x | SPISIMOA<br>SPISOMIA<br>SPICLKA<br>SPIESTEA |  | Serial SPI<br>EEPROM<br>DIN<br>DOUT<br>CLK<br><del>CS</del> |
|-----|---------------------------------------------|--|-------------------------------------------------------------|
|-----|---------------------------------------------|--|-------------------------------------------------------------|

#### Figure 2-19. SPI Loader

The SPI-A loader uses following pins:

- SPISIMOA on GPIO16
- SPISOMIA on GPIO17
- SPICLKA on GPIO18
- SPISTEA on GPIO19

The SPI boot ROM loader initializes the SPI module to interface to a serial SPI EEPROM or flash. Devices of this type include, but are not limited to, the Xicor X25320 (4Kx8) and Xicor X25256 (32Kx8) SPI serial SPI EEPROMs and the Atmel AT25F1024A serial flash.

The SPI boot ROM loader initializes the SPI with the following settings: FIFO enabled, 8-bit character, internal SPICLK master mode and talk mode, clock phase = 1, polarity = 0, using the slowest baud rate.

If the download is to be performed from an SPI port on another device, then that device must be setup to operate in the slave mode and mimic a serial SPI EEPROM. Immediately after entering the SPI\_Boot function, the pin functions for the SPI pins are set to primary and the SPI is initialized. The initialization is done at the slowest speed possible. Once the SPI is initialized and the key value read, you could specify a change in baud rate or low speed peripheral clock.

| Byte | Contents                                                                                                   |
|------|------------------------------------------------------------------------------------------------------------|
| 1    | LSB: AA (KeyValue for memory width = 8-bits)                                                               |
| 2    | MSB: 08h (KeyValue for memory width = 8-bits)                                                              |
| 3    | LSB: LOSPCP                                                                                                |
| 4    | MSB: SPIBRR                                                                                                |
| 5    | LSB: reserved for future use                                                                               |
| 6    | MSB: reserved for future use                                                                               |
|      | <br>Data for this section.                                                                                 |
|      |                                                                                                            |
| 17   | LSB: reserved for future use                                                                               |
| 18   | MSB: reserved for future use                                                                               |
| 19   | LSB: Upper half (MSW) of Entry point PC[23:16]                                                             |
| 20   | MSB: Upper half (MSW) of Entry point PC[31:24] (Note: Always 0x00)                                         |
| 21   | LSB: Lower half (LSW) of Entry point PC[7:0]                                                               |
| 22   | MSB: Lower half (LSW) of Entry point PC[15:8]                                                              |
|      | Data for this section.                                                                                     |
|      |                                                                                                            |
|      | Blocks of data in the format size/destination address/data as shown in the generic data stream description |

#### Table 2-13. SPI 8-Bit Data Stream

|      | Table 2-13. SPI 6-bit Data Stream (continued) |  |  |  |  |
|------|-----------------------------------------------|--|--|--|--|
| Byte | Contents                                      |  |  |  |  |
|      |                                               |  |  |  |  |
|      | Data for this section.                        |  |  |  |  |
|      |                                               |  |  |  |  |
| n    | LSB: 00h                                      |  |  |  |  |
| n+1  | MSB: 00h - indicates the end of the source    |  |  |  |  |

 Table 2-13. SPI 8-Bit Data Stream (continued)

The data transfer is done in "burst" mode from the serial SPI EEPROM. The transfer is carried out entirely in byte mode (SPI at 8 bits/character). A step-by-step description of the sequence follows:

- Step 1. The SPI-A port is initialized
- Step 2. The GPIO19 (SPISTE) pin is used as a chip-select for the serial SPI EEPROM or flash
- Step 3. The SPI-A outputs a read command for the serial SPI EEPROM or flash
- Step 4. The SPI-A sends the serial SPI EEPROM an address 0x0000; that is, the host requires that the EEPROM or flash must have the downloadable packet starting at address 0x0000 in the EEPROM or flash. The loader is compatible with both 16-bit addresses and 24-bit addresses.
- Step 5. The next word fetched must match the key value for an 8-bit data stream (0x08AA). The least significant byte of this word is the byte read first and the most significant byte is the next byte fetched. This is true of all word transfers on the SPI. If the key value does not match, then the load is aborted.
- Step 6. The next 2 bytes fetched can be used to change the value of the low speed peripheral clock register (LOSPCP) and the SPI baud rate register (SPIBRR). The first byte read is the LOSPCP value and the second byte read is the SPIBRR value. The next 7 words are reserved for future enhancements. The SPI bootloader reads these 7 words and discards them.
- Step 7. The next 2 words makeup the 32-bit entry point address where execution will continue after the boot load process is complete. This is typically the entry point for the program being downloaded through the SPI port.
- Step 8. Multiple blocks of code and data are then copied into memory from the external serial SPI EEPROM through the SPI port. The blocks of code are organized in the standard data stream structure presented earlier. This is done until a block size of 0x0000 is encountered. At that point in time the entry point address is returned to the calling routine that then exits the bootloader and resumes execution at the address specified.



Figure 2-20. Data Transfer From EEPROM Flow







# 2.1.5.19 I2C Boot Function

The I2C bootloader expects an 8-bit wide I2C-compatible EEPROM device to be present at address 0x50 on the I2C-A bus as indicated in Figure 2-22. The EEPROM must adhere to conventional I2C EEPROM protocol, as described in this section, with a 16-bit base address architecture.





The I2C loader uses following pins:

- SDAA on GPIO 28
- SCLA on GPIO 29

If the download is to be performed from a device other than an EEPROM, then that device must be set up to operate in the slave mode and mimic the I2C EEPROM. Immediately after entering the I2C boot function, the GPIO pins are configured for I2C-A operation and the I2C is initialized. The following requirements must be met when booting from the I2C module:

- The input frequency to the device must be in the appropriate range.
- The EEPROM must be at slave address 0x50.



Figure 2-23. Overview of I2C\_Boot Function

The bit-period prescalers (I2CCLKH and I2CCLKL) are configured by the bootloader to run the I2C at a 50 percent duty cycle at 100-kHz bit rate (standard I2C mode) when the system clock is 10 MHz. These registers can be modified after receiving the first few bytes from the EEPROM. This allows the communication to be increased up to a 400-kHz bit rate (fast I2C mode) during the remaining data reads.

Arbitration, bus busy, and slave signals are not checked. Therefore, no other master is allowed to control the bus during this initialization phase. If the application requires another master during I2C boot mode, that master must be configured to hold off sending any I2C messages until the application software signals that it is past the bootloader portion of initialization.

The non-acknowledgment bit is checked only during the first message sent to initialize the EEPROM base address. This is to make sure that an EEPROM is present at address 0x50 before continuing. If an EEPROM is not present, code will enable the watchdog and force a device reset through software. The non-acknowledgment bit is not checked during the address phase of the data read messages (I2C\_Get Word). If a non-acknowledgment is received during the data read messages, the I2C bus will hang. Table 3-2 shows the 8-bit data stream used by the I2C.

Texas **STRUMENTS** 

www.ti.com

| Byte                                            | Contents                                                                                                        |  |  |  |
|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|
| 1                                               | LSB: AA (KeyValue for memory width = 8 bits)                                                                    |  |  |  |
| 2 MSB: 08h (KeyValue for memory width = 8 bits) |                                                                                                                 |  |  |  |
| 3                                               | LSB: I2CPSC[7:0]                                                                                                |  |  |  |
| 4                                               | reserved                                                                                                        |  |  |  |
| 5                                               | LSB: I2CCLKH[7:0]                                                                                               |  |  |  |
| 6                                               | MSB: I2CCLKH[15:8]                                                                                              |  |  |  |
| 7                                               | LSB: I2CCLKL[7:0]                                                                                               |  |  |  |
| 8                                               | MSB: I2CCLKL[15:8]                                                                                              |  |  |  |
|                                                 | <br>Data for this section.<br>                                                                                  |  |  |  |
| 17                                              | 17 LSB: Reserved for future use                                                                                 |  |  |  |
| 18                                              | MSB: Reserved for future use                                                                                    |  |  |  |
| 19                                              | LSB: Upper half of entry point PC                                                                               |  |  |  |
| 20                                              | MSB: Upper half of entry point PC[22:16] (Note: Always 0x00)                                                    |  |  |  |
| 21                                              | LSB: Lower half of entry point PC[15:8]                                                                         |  |  |  |
| 22                                              | MSB: Lower half of entry point PC[7:0]                                                                          |  |  |  |
|                                                 | <br>Data for this section.                                                                                      |  |  |  |
|                                                 | <br>Blocks of data in the format size/destination address/data as shown in the generic data stream description. |  |  |  |
|                                                 | un<br>Dete fan dele energiese                                                                                   |  |  |  |
|                                                 | Data for this section.                                                                                          |  |  |  |
| n                                               | LSB: 00h                                                                                                        |  |  |  |
| n+1                                             | MSB: 00h - indicates the end of the source                                                                      |  |  |  |

Table 2-14, I2C 8-Bit Data Stream

The I2C EEPROM protocol required by the I2C bootloader is shown in Figure 2-24 and Figure 2-25. The first communication, which sets the EEPROM address pointer to 0x0000 and reads the KeyValue (0x08AA) from it, is shown in Figure 2-24. All subsequent reads are shown in Figure 2-25 and are read two bytes at a time.



## Figure 2-24. Random Read

#### Boot ROM

## 2.1.5.20 eCAN Boot Function

The eCAN bootloader asynchronously transfers code from eCAN-A to internal memory. The host can be any CAN node. The communication is first done with 11-bit standard identifiers (with a MSGID of 0x1) using two bytes per data frame. The host can download a kernel to reconfigure the eCAN if higher data throughput is desired.

The eCAN-A loader uses following pins:

- CANRXA on GPIO30
- CANTXA on GPIO31





The bit-timing registers are programmed in such a way that a valid bit-rate is achieved for a 10 MHz internal oscillator frequency as shown in Table 2-15.

| Table 2-15. Bit-Rate Value for Internal Oscillato | ors |
|---------------------------------------------------|-----|
|---------------------------------------------------|-----|

| OSCCLK | SYSCLKOUT | Bit Rate |
|--------|-----------|----------|
| 10 MHz | 10 MHz    | 100 kbps |

The SYSCLKOUT values shown are the reset values with the default PLL setting. The BRP<sub>reg</sub> and bit-time values are hard-coded to 1 and 25, respectively.

Mailbox 1 is programmed with a standard MSGID of 0x1 for boot-loader communication. The CAN host should transmit only 2 bytes at a time, LSB first and MSB next. For example, to transmit the word 0x08AA to the device, transmit AA first, followed by 08. The program flow of the CAN bootloader is identical to the SCI bootloader. The data sequence for the CAN bootloader is shown in Table 2-16:

| www.ti.com | www. | ti.o | com |
|------------|------|------|-----|
|------------|------|------|-----|

Boot ROM

| Bytes Byte 1 of 2 Byte 2 of 2 Description |     |    |    | Description                                                                        |
|-------------------------------------------|-----|----|----|------------------------------------------------------------------------------------|
| 1                                         | 2   | AA | 08 | 0x08AA (KeyValue for memory width = 16bits)                                        |
| 3                                         | 4   | 00 | 00 | reserved                                                                           |
| 5                                         | 6   | 00 | 00 | reserved                                                                           |
| 7                                         | 8   | 00 | 00 | reserved                                                                           |
| 9                                         | 10  | 00 | 00 | reserved                                                                           |
| 11                                        | 12  | 00 | 00 | reserved                                                                           |
| 13                                        | 14  | 00 | 00 | reserved                                                                           |
| 15                                        | 16  | 00 | 00 | reserved                                                                           |
| 17                                        | 18  | 00 | 00 | reserved                                                                           |
| 19                                        | 20  | BB | 00 | Entry point PC[22:16]                                                              |
| 21                                        | 22  | DD | CC | Entry point PC[15:0] (PC = 0xAABBCCDD)                                             |
| 23                                        | 24  | NN | MM | Block size of the first block of data to load = 0xMMNN words                       |
| 25                                        | 26  | BB | AA | Destination address of first block Addr[31:16]                                     |
| 27                                        | 28  | DD | CC | Destination address of first block Addr[15:0] (Addr = 0xAABBCCDD)                  |
| 29                                        | 30  | BB | AA | First word of the first block in the source being loaded = 0xAABB                  |
| <br>                                      |     |    |    | <br>Data for this section.<br>                                                     |
|                                           |     | BB | AA | Last word of the first block of the source being loaded = 0xAABB                   |
|                                           |     | NN | MM | Block size of the 2nd block to load = 0xMMNN words                                 |
|                                           |     | BB | AA | Destination address of second block Addr[31:16]                                    |
|                                           |     | DD | СС | Destination address of second block Addr[15:0]                                     |
|                                           |     | BB | AA | First word of the second block in the source being loaded                          |
|                                           |     |    |    |                                                                                    |
| n                                         | n+1 | BB | AA | Last word of the last block of the source being loaded (More sections if required) |
| n+2                                       | n+3 | 00 | 00 | Block size of 0000h - indicates end of the source program                          |

Table 2-16. eCAN 8-Bit Data Stream



#### 2.1.5.21 ExitBoot Assembly Routine

The boot ROM includes an ExitBoot routine that restores the CPU registers to their default state at reset. This is performed on all registers with one exception. The OBJMODE bit in ST1 is left set so that the device remains configured for C28x operation. This flow is detailed in the following diagram:





The following CPU registers are restored to their default values:

- ACC = 0x0000 0000
- RPC = 0x0000 0000
- P = 0x0000 0000
- XT = 0x0000 0000
- ST0 = 0x0000
- ST1 = 0x0A0B
- XAR0 = XAR7 = 0x0000 0000

After the ExitBoot routine completes and the program flow is redirected to the entry point address, the CPU registers will have the following values:

# TEXAS INSTRUMENTS

| Register  | Value      |       |         | Register | Value       |       |              |
|-----------|------------|-------|---------|----------|-------------|-------|--------------|
| ACC       | 0x0000 000 | 00    |         | Р        | 0x0000 0000 |       |              |
| ХТ        | 0x0000 000 | 00    |         | RPC      | 0x00 0000   |       |              |
| XAR0-XAR7 | 0x0000 000 | 00    |         | DP       | 0x0000      |       |              |
| ST0       | 0x0000     | 15:10 | OVC = 0 | ST1      | 0x0A0B      | 15:13 | ARP = 0      |
|           |            | 9:7   | PM = 0  |          |             | 12    | XF = 0       |
|           |            | 6     | V = 0   |          |             | 11    | MOM1MAP = 1  |
|           |            | 5     | N = 0   |          |             | 10    | reserved     |
|           |            | 4     | Z = 0   |          |             | 9     | OBJMODE = 1  |
|           |            | 3     | C = 0   |          |             | 8     | AMODE = 0    |
|           |            | 2     | TC = 0  |          |             | 7     | IDLESTAT = 0 |
|           |            | 1     | OVM = 0 |          |             | 6     | EALLOW = 0   |
|           |            | 0     | SXM = 0 |          |             | 5     | LOOP = 0     |
|           |            |       |         |          |             | 4     | SPA = 0      |
|           |            |       |         |          |             | 3     | VMAP = 1     |
|           |            |       |         |          |             | 2     | PAGE0 = 0    |
|           |            |       |         |          |             | 1     | DBGM = 1     |
|           |            |       |         |          |             | 0     | INTM = 1     |

www.ti.com

Table 2-17. CPU Register Restored Values

# 2.1.6 Building the Boot Table

This section explains how to generate the data stream and boot table required for the bootloader.

## 2.1.6.1 The C2000 Hex Utility

To use the features of the bootloader, you must generate a data stream and boot table as described in Section 2.1.5.11. The hex conversion utility tool, included with the 28x code generation tools, can generate the required data stream including the required boot table. This section describes the hex2000 utility. An example of a file conversion performed by hex2000 is described in Section 2.1.6.1.1.

The hex utility supports creation of the boot table required for the SCI, SPI, I2C, eCAN, and parallel I/O loaders. That is, the hex utility adds the required information to the file such as the key value, reserved bits, entry point, address, block start address, block length and terminating value. The contents of the boot table vary slightly depending on the boot mode and the options selected when running the hex conversion utility. The actual file format required by the host (ASCII, binary, hex, etc.) will differ from one specific application to another and some additional conversion may be required.

To build the boot table, follow these steps:

## 1. Assemble or compile the code.

This creates the object files that will then be used by the linker to create a single output file.

## 2. Link the file.

The linker combines all of the object files into a single output file in common object file format (COFF). The specified linker command file is used by the linker to allocate the code sections to different memory blocks. Each block of the boot table data corresponds to an initialized section in the COFF file. Uninitialized sections are not converted by the hex conversion utility. The following options may be useful:

The linker -m option can be used to generate a map file. This map file will show all of the sections that were created, their location in memory and their length. It can be useful to check this file to make sure that the initialized sections are where you expect them to be.

The linker -w option is also very useful. This option will tell you if the linker has assigned a section to a memory region on its own. For example, if you have a section in your code called ramfuncs.

## 3. Run the hex conversion utility.

Choose the appropriate options for the desired boot mode and run the hex conversion utility to convert

the COFF file produced by the linker to a boot table.

See the TMS320C28x Assembly Language Tools User's Guide (SPRU513) and the TMS320C28x Optimizing C/C++ Compiler User's Guide (SPRU514) for more information on the compiling and linking process.

Table 2-18 summarizes the hex conversion utility options available for the bootloader. See the *TMS320C28x Assembly Language Tools User's Guide* (SPRU513) for a detailed description of the hex2000 operations used to generate a boot table. Updates will be made to support the I2C boot. See the Codegen release notes for the latest information.

| Option         | Description                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| -boot          | Convert all sections into bootable form (use instead of a SECTIONS directive)                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| -sci8          | Specify the source of the bootloader table as the SCI-A port, 8-bit mode                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| -spi8          | Specify the source of the bootloader table as the SPI-A port, 8-bit mode                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| -gpio8         | Specify the source of the bootloader table as the GPIO port, 8-bit mode                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| -gpio16        | Specify the source of the bootloader table as the GPIO port, 16-bit mode                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| -bootorg value | Specify the source address of the bootloader table                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| -lospcp value  | Specify the initial value for the LOSPCP register. This value is used only for the spi8 boot table format and ignored for all other formats. If the value is greater than 0x7F, the value is truncated to 0x7F.                                                                                                                                                                |  |  |  |  |  |  |
| -spibrr value  | Specify the initial value for the SPIBRR register. This value is used only for the spi8 boot table format and ignored for all other formats. If the value is greater than 0x7F, the value is truncated to 0x7F.                                                                                                                                                                |  |  |  |  |  |  |
| -e value       | Specify the entry point at which to begin execution after boot loading. The value can be an address or a global symbol. This value is optional. The entry point can be defined at compile time using the linker -e option to assign the entry point to a global symbol. The entry point for a C program is normally _c_int00 unless defined otherwise by the -e linker option. |  |  |  |  |  |  |
| -i2c8          | Specify the source of the bootloader table as the I2C-A port, 8-bit                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| -i2cpsc value  | Specify the value for the I2CPSC register. This value will be loaded and take effect after all I2C options<br>are loaded, prior to reading data from the EEPROM. This value will be truncated to the least significant<br>eight bits and should be set to maintain an I2C module clock of 7-12 MHz.                                                                            |  |  |  |  |  |  |
| -i2cclkh value | Specify the value for the I2CCLKH register. This value will be loaded and take effect after all I2C options are loaded, prior to reading data from the EEPROM.                                                                                                                                                                                                                 |  |  |  |  |  |  |
| -i2cclkl value | Specify the value for the I2CCLKL register. This value will be loaded and take effect after all I2C options are loaded, prior to reading data from the EEPROM.                                                                                                                                                                                                                 |  |  |  |  |  |  |

#### Table 2-18. Bootloader Options

# 2.1.6.1.1 Example: Preparing a COFF File For eCAN Bootloading

This section shows how to convert a COFF file into a format suitable for CAN based bootloading. This example assumes that the host sending the data stream is capable of reading an ASCII hex format file. An example COFF file named GPIO34TOG.out has been used for the conversion.

Build the project and link using the -m linker option to generate a map file. Examine the .map file produced by the linker. The information shown in Example 2-7 has been copied from the example map file (GPIO34TOG.map). This shows the section allocation map for the code. The map file includes the following information:

## Output Section

This is the name of the output section specified with the SECTIONS directive in the linker command file.

Origin

The first origin listed for each output section is the starting address of that entire output section. The following origin values are the starting address of that portion of the output section.

Length

The first length listed for each output section is the length for that entire output section. The following length values are the lengths associated with that portion of the output section.

## Attributes/input sections

This lists the input files that are part of the section or any value associated with an output section.

See the *TMS320C28x* Assembly Language Tools User's Guide (SPRU513) for detailed information on generating a linker command file and a memory map.

All sections shown in Example 2-7 that are initialized need to be loaded into the DSP in order for the code to execute properly. In this case, the codestart, ramfuncs, .cinit, myreset and .text sections need to be loaded. The other sections are uninitialized and will not be included in the loading process. The map file also indicates the size of each section and the starting address. For example, the .text section has 0x155 words and starts at 0x3FA000.

Example 2-7. GPIO34TOG Map File

| output<br>section | page | origin   | length   | attributes/<br>input sections          |
|-------------------|------|----------|----------|----------------------------------------|
| codestart         |      |          |          |                                        |
|                   | 0    | 00000000 | 0000002  |                                        |
|                   |      | 00000000 | 0000002  | F2805x_CodeStartBranch.obj (codestart) |
| .pinit            | 0    | 0000002  | 00000000 |                                        |
| .switch           | 0    | 00000002 | 00000000 | UNINITIALIZED                          |
| ramfuncs          | 0    | 00000002 | 00000016 |                                        |
|                   |      | 0000002  | 00000016 | F2805x_SysCtrl.obj (ramfuncs)          |
| .cinit            | 0    | 00000018 | 00000019 |                                        |
|                   |      | 0000018  | 0000000e | rts2800_ml.lib : exit.obj (.cinit)     |
|                   |      | 00000026 | 0000000a | : _lock.obj (.cinit)                   |
|                   |      | 0000030  | 00000001 | HOLE [fill = 0]                        |
| myreset           | 0    | 0000032  | 00000002 |                                        |
|                   |      | 0000032  | 0000002  | F2805x_CodeStartBranch.obj (myreset)   |
| IQmath            | 0    | 003fa000 | 00000000 | UNINITIALIZED                          |
| .text             | 0    | 003fa000 | 00000155 |                                        |
|                   | U U  | 003fa000 | 00000046 | rts2800_ml.lib : boot.obj (.text)      |

To load the code using the CAN bootloader, the host must send the data in the format that the bootloader understands. That is, the data must be sent as blocks of data with a size, starting address followed by the data. A block size of 0 indicates the end of the data. The HEX2000.exe utility can be used to convert the COFF file into a format that includes this boot information. The following command syntax has been used to convert the application into an ASCII hex format file that includes all of the required information for the bootloader:

Example 2-8. HEX2000.exe Command Syntax



#### Boot ROM

www.ti.com

The command line shown in Example 2-8 will generate an ASCII-Hex output file called GPIO34TOG.a00, whose contents are explained in Example 2-9. This example assumes that the host will be able to read an ASCII hex format file. The format may differ for your application. . Each section of data loaded can be tied back to the map file described in Example 2-7. After the data stream is loaded, the boot ROM will jump to the Entrypoint address that was read as part of the data stream. In this case, execution will begin at 0x3FA0000.

#### Example 2-9. GPIO34TOG Data Stream

AA 08 ;Keyvalue 00 00 00 00 00 00 00 00 ;8 reserved words 00 00 00 00 00 00 00 00 3F 00 00 A0 ;Entrypoint 0x003FA000 02 00 ;Load 2 words - codestart section 00 00 00 00 ;Load block starting at 0x000000 ;Data block 0x007F, 0xA09A 7F 00 9A A0 16 00 ;Load 0x0016 words - ramfuncs section 00 00 02 00 ;Load block starting at 0x000002 22 76 1F 76 2A 00 00 1A 01 00 06 CC F0 ;Data = 0x7522, 0x761F etc... FF 05 50 06 96 06 CC FF F0 A9 1A 00 05 06 96 04 1A FF 00 05 1A FF 00 1A 76 07 F6 00 77 06 00 55 01 ;Load 0x0155 words - .text section 3F 00 00 A0 ;Load block starting at 0x003FA000 AD 28 00 04 69 FF 1F 56 16 56 1A 56 40 ;Data = 0x28AD, 0x4000 etc... 29 1F 76 00 00 02 29 1B 76 22 76 A9 28 18 00 A8 28 00 00 01 09 1D 61 C0 76 18 00 04 29 OF 6F 00 9B A9 24 01 DF 04 6C 04 29 A8 24 01 DF A6 1E A1 F7 86 24 A7 06 .. .. .. .. .. .. .. .. FC 63 E6 6F 19 00 ;Load 0x0019 words - .cinit section 00 00 18 00 ;Load block starting at 0x000018 FF FF 00 B0 3F 00 00 00 FE FF 02 B0 3F ;Data = 0xFFFF, 0xB000 etc... 00 00 00 00 00 FE FF 04 B0 3F 00 00 00 00 00 FE FF .. .. .. .. .. .. 3F 00 00 00 02 00 ;Load 0x0002 words - myreset section 00 00 32 00 ;Load block starting at 0x000032 00 00 00 00 ;Data = 0x0000, 0x0000;Block size of 0 - end of data 00 00



# 2.1.7 Bootloader Code Overview

This chapter contains information on the boot ROM version, checksum, and code.

#### 2.1.7.1 Boot ROM Version and Checksum Information

The boot ROM contains its own version number located at address 0x3F FFBA. This device has three kinds of ROM(s), each with its own usage and Software Development Life Cycle, so, a version for each is needed. Unsecure boot ROM stores the version info for each of the ROM as shown in Table 2-19.

Bits [7-4] of Version No at location 0x3F FFBA stores a vversion of Secure ROM contents on this device. Bits[11-8] of Version No at location 0x3F FFBA stores version of BootROM contents on this device. Rest of the bits are reserved in this location are reserved.

CLA DATA ROM has its own version and revision number defined later in this document.

This version number starts at 1 and will be incremented any time the boot ROM code is modified. The next address, 0x3F FFBB contains the month and year (MM/YY in decimal) that the boot code was released. The next four memory locations contain a checksum value for the boot ROM. Taking a 64-bit summation of all addresses within the ROM, except for the checksum locations, generates this checksum.

| Address   | Contents                           |  |  |  |  |  |
|-----------|------------------------------------|--|--|--|--|--|
| 0x3F FFB9 |                                    |  |  |  |  |  |
| 0x3F FFBA | Boot ROM Version Number            |  |  |  |  |  |
| 0x3F FFBB | MM/YY of release (in decimal)      |  |  |  |  |  |
| 0x3F FFBC | Least significant word of checksum |  |  |  |  |  |
| 0x3F FFBD |                                    |  |  |  |  |  |
| 0x3F FFBE |                                    |  |  |  |  |  |
| 0x3F FFBF | Most significant word of checksum  |  |  |  |  |  |

#### Table 2-19. Bootloader Revision and Checksum Information

Table 2-20 shows the boot ROM revision per device. A revision history and code listing for the latest boot ROM code can be found in Section 2.1.7. In addition, the actual boot ROM sources are included in the latest version of the ControlSuite release.

| Device(s) | Silicon REVID<br>(Address 0x883) | Boot ROM Revision |
|-----------|----------------------------------|-------------------|
| F2805x    | 0 (First silicon)                | Version 1         |

#### 2.1.7.2 ROM API Entry Point Table

This device includes a ROM API Entry point table as shown in Table 2-21. This table contains entry points to the flash API library that is located in ROM. The ROM Flash API library released to customers will allow user software applications to link to this ROM API table whenever a flash API (in ROM) is called. Having the ROM API table gives the flexibility of moving the flash API locations in ROM without having users recompile their application.

The ROM Flash API library that is released for the device links the application code to the entry points in the table, so there is no effort on the users' part to use this API table. Please refer to Flash API Library documentation for more information on the Flash API.

| Address   | Contents                   |
|-----------|----------------------------|
| 0x3F FEB9 | ROM_API_TABLE Version      |
| 0x3F FEBB | ROM_API_TABLE Release Date |
| 0x3F FEBD | Flash Program              |

#### Table 2-21. ROM API Entry point

| Table 2-21. ROM API Entry po | oint (continued) |
|------------------------------|------------------|
|------------------------------|------------------|

| 0x3F FFBF | Flash Erase |
|-----------|-------------|
| 0x3F FFC1 | EraseVerify |
| 0x3F FFC3 |             |
|           |             |
| 0x3F FFBE |             |
| 0x3F FFB8 |             |

# 2.2 CLA DATA ROM

CLA DATA ROM is a 4K x 16 block of read-only memory mapped at address 0xF000-0xFFFF. The CLA DATA ROM is programmed with CLA Math Tables that are explained in this section.

Figure 2-28 shows the memory map of on-chip CLA ROM.

| CLA Data ROM         |                        |
|----------------------|------------------------|
| Data Space           | Section Start          |
| Reserved             | 0x00 F000              |
| CLA Tables           | 0x00 F870              |
| CLA DataROM Version  | 0x00 FFFA<br>0x00 FFFC |
| CLA DataROM Checksum | 0x00 FFFF              |

#### Figure 2-28. CLA Data ROM

# 2.2.1 On-Chip CLA Data ROM Math Tables

The CLA Math Tables included in the Data ROM are used by the CLAmath Library. This library is a collection of optimized floating-point math functions for controllers with the CLA and can be used in either assembly or C(with CLA C compiler enabled codegen tools) context

The routines are coded in assembly and have been hand optimized to provide fast execution speed and good accuracy. The C programming model for the CLA does not support the standard ANSI C Math library that is available for use on the C28x. The CLAmath library supports all the standard math routines and must be used instead.

The routines in the CLAmath library make use of lookup tables to speed up execution time and access them through the CLA1mathTables linker section. This section is completely included in the data ROM. If you do not wish to load a copy of these tables already included in the ROM into the device, use the data ROM memory address and label the section as "NOLOAD" as shown in Example 1. This facilitates referencing the look-up tables without actually loading the section to the target.

The preferred alternative to using the linker command file is to use the CLAmath data ROM symbol library. If this library is linked in the project before the CLAmath library, and the linker -priority option is used, then any math tables and CLAmath functions within the data ROM will be used first. Refer to the CLAmath library documentation for more information

#### **Example 1: Linker Command File to Access IQ Tables**

```
MEMORY
{
...
PAGE 1 :
...
CLA1_DATAROM : origin = 0x00F000, length = 0x001000
...
}
SECTIONS
{
```



```
...
CLAlmathTables : > CLA1_DATAROM, PAGE = 1 , TYPE = NOLOAD
...
```

}

The following math tables are included in the Data ROM

- Sine/Cosine Table
  - Table size: 322 words (161 x 2) M
  - Contents: 161 32-bit floating point samples for the interval [0,2\*pi] This is useful for sine or cosine wave generation wave generation and to calculate The twiddle factors in an FFT
- Arc-Cosine Table
  - Table size: 384 words ( $64 \times 3 \times 2$ )
  - Contents: 64 32-bit floating point coefficient triplets used in the polynomial approximation of the function in the interval [0, pi]
- Arc-Sine Table
  - Table size: 384 words (64 x 3 x 2
  - Contents: 64 32-bit floating point coefficient triplets used in the polynomial approximation of the function in the interval [0, pi
- Arc-Tan Table
  - Table size: 384 words (64 x 3 x 2)
  - Contents: 64 32-bit floating point coefficient triplets used in the polynomial approximation of the function in the interval [0, pi]
     This is useful in phase calculations for FFTs
- Exponential Table
  - Table size: 194 words (89 x 2 + 7 x 2 + 1 x 2)
  - Contents: 7 32-bit floating point coefficients for the taylor series expansion of the exponential function, 1 32-bit floating point constant i.e. log10(e) and 89 32-bit floating point exponents of the first 89 integers i.e., e0 to e88
- Natural Logarithm Table
  - Table size: 210 words (33 x 3 x 2 + 6 x 2)
  - Contents: 33 32-bit floating point coefficient triplets used in the polynomial approximation of the fractional part of the argument

# 2.2.2 CLA DataROM Version and Checksum

CLA DataROM stores its own version number, release information and checksum information similar to boot ROM as shown below.

| Address    | Contents                           |
|------------|------------------------------------|
| 0x0000FFFA | CLA Data ROM Version Number        |
| 0x0000FFFB | MM/YY of release (in decimal)      |
| 0x0000FFFC | Least significant word of checksum |
| 0x0000FFFD |                                    |
| 0x0000FFFE |                                    |
| 0x0000FFFF | Most significant word of checksum  |

#### Table 2-22. CLA DataROM Version and Checksum Information

CLA DATA ROM

The CLA checksum is computed over the entire CLA Data ROM contents only.

# 2.3 Secure ROM

Secure ROM is a 2K x 16 block of EXE ONLY memory located at address 0x3F8000-0x3F8800. Secure ROM on this device is divided into three sections as shown in Figure 2-29. To allow code to be copied from Z1EXEONLY flash to Z1EXEONLY RAM, the first 1K x16 words of secure ROM is configured as Z1 and contains the Safe Copy Code function for Z1 user applications to call.

The second 1K x 16 words of secure ROM is configured for Z2 and contains the Safe Copy Code function for Z2 user applications to copy code from Z2EXEONLY flash to Z2EXEONLY RAM.

The rest of the secure ROM is configured for Z1 and at present, is reserved for TI use. Figure 2-29 shows the device's secure ROM memory map.

| Secure ROM ( | Section Start |
|--------------|---------------|
| Data Space   |               |
| Z1 Secure    | 0x3F 8000     |
| func         | 0x3F 8400     |
| Z2 Secure    |               |
| func         | 0x3F 8800     |

Figure 2-29. Secure ROM

# 2.3.1 Safe Copy code Functions (Z1 and Z2)

To allow code copy from an EXEONLY flash sector to a secured RAM belonging to the same zone, dedicated TI-provided code copy functions which are residing in secure ROM, should be used. These functions are denoted as SafeCopyCodeZ1() (for zone1) and SafeCopeCodeZ2() (for zone2) and are supported by hardware to allow users copy the data residing in EXEONLY flash sectors to RAM without compromising security.

The application must ensure that the interrupts are disabled before calling the SafeCopyCodeZx() functions. The device will reset if an interrupt, NMI, or iTRAP is fetched during function execution.

Example use of copy function:

```
STEC INTM
Status = SafeCopyCodeZx(size,(uint16 *)dest, (uint16 *)src);
CLRC INTM
Prototypes:
Uint16 SafeCopycodeZ1(Uint32 size, Uint16 *dst, Uint16 *src);
Uint16 SafeCopycodeZ2(Uint32 size, Uint16 *dst, Uint16 *src);
```

The function returns the number of words copied.

The application must enure that the src flash sector and dst RAM belongs to the same Zone and variables src, src+size should fall within a sector boundary and dst, dst+size should fall within a RAM block boundary.





# Enhanced Pulse Width Modulator (ePWM) Module

The enhanced pulse width modulator (ePWM) peripheral is a key element in controlling many of the power electronic systems found in both commercial and industrial equipments. These systems include digital motor control, switch mode power supply control, uninterruptible power supplies (UPS), and other forms of power conversion. The ePWM peripheral performs a digital to analog (DAC) function, where the duty cycle is equivalent to a DAC analog value; it is sometimes referred to as a Power DAC.

This reference guide is applicable for ePWM type 1. See the *TMS320x28xx, 28xxx DSP Peripheral Reference Guide* (SPRU566) for a list of all devices with an ePWM module of the same type, to determine the differences between the types, and for a list of device-specific differences within a type.

This chapter includes an overview of the module and information about each of its sub-modules:

- Time-Base Module
- Counter Compare Module
- Action Qualifier Module
- Dead-Band Generator Module
- PWM Chopper (PC) Module
- Trip Zone Module
- Event Trigger Module

ePWM Type 1 is fully compatible to the Type 0 module. Type 1 has the following enhancements in addition to the Type 0 features:

#### Increased Dead-Band Resolution

The dead-band clocking has been enhanced to allow half-cycle clocking to double resolution.

#### Enhanced interrupt and SOC generation

Interrupts and ADC start-of-conversion can now be generated on both the TBCTR == zero and TBCTR == period events. This feature enables dual edge PWM control. Additionally, the ADC start-of-conversion can be generated from an event defined in the digital compare sub-module.

#### • Digital Compare Sub-module

The digital compare sub-module enhances the event triggering and trip zone sub-modules by providing filtering, blanking and improved trip functionality to digital compare signals. Such features are essential for peak current mode control and for support of analog comparators.

| opic |                                  | Page |
|------|----------------------------------|------|
| 3.1  | Introduction                     | 258  |
| 3.2  | ePWM Submodules                  | 264  |
| 3.3  | Applications to Power Topologies | 319  |
| 3.4  | Registers                        | 343  |

### 3.1 Introduction

An effective PWM peripheral must be able to generate complex pulse width waveforms with minimal CPU overhead or intervention. It needs to be highly programmable and very flexible while being easy to understand and use. The ePWM unit described here addresses these requirements by allocating all needed timing and control resources on a per PWM channel basis. Cross coupling or sharing of resources has been avoided; instead, the ePWM is built up from smaller single channel modules with separate resources that can operate together as required to form a system. This modular approach results in an orthogonal architecture and provides a more transparent view of the peripheral structure, helping users to understand its operation quickly.

In this document the letter x within a signal or module name is used to indicate a generic ePWM instance on a device. For example output signals EPWMxA and EPWMxB refer to the output signals from the ePWMx instance. Thus, EPWM1A and EPWM1B belong to ePWM1 and likewise EPWM4A and EPWM4B belong to ePWM4.

## 3.1.1 Submodule Overview

The ePWM module represents one complete PWM channel composed of two PWM outputs: EPWMxA and EPWMxB. Multiple ePWM modules are instanced within a device as shown in Figure 3-1. Each ePWM instance is identical with one exception. Each ePWM module is indicated by a numerical value starting with 1. For example ePWM1 is the first instance and ePWM3 is the third instance in the system and ePWMx indicates any instance.

The ePWM modules are chained together via a clock synchronization scheme that allows them to operate as a single system when required. Additionally, this synchronization scheme can be extended to the capture peripheral modules (eCAP). The number of modules is device-dependent and based on target application needs. Modules can also operate stand-alone.

Each ePWM module supports the following features:

- Dedicated 16-bit time-base counter with period and frequency control
- Two PWM outputs (EPWMxA and EPWMxB) that can be used in the following configurations:
  - Two independent PWM outputs with single-edge operation
  - Two independent PWM outputs with dual-edge symmetric operation
  - One independent PWM output with dual-edge asymmetric operation
- Asynchronous override control of PWM signals through software.
- Programmable phase-control support for lag or lead operation relative to other ePWM modules.
- Hardware-locked (synchronized) phase relationship on a cycle-by-cycle basis.
- Dead-band generation with independent rising and falling edge delay control.
- Programmable trip zone allocation of both cycle-by-cycle trip and one-shot trip on fault conditions.
- A trip condition can force either high, low, or high-impedance state logic levels at PWM outputs.
- Comparator module outputs and trip zone inputs can generate events, filtered events, or trip conditions.
- All events can trigger both CPU interrupts and ADC start of conversion (SOC)
- Programmable event prescaling minimizes CPU overhead on interrupts.
- PWM chopping by high-frequency carrier signal, useful for pulse transformer gate drives.

Each ePWM module is connected to the input/output signals shown in Figure 3-1. The signals are described in detail in subsequent sections.







A This signal exists only on devices with an eQEP1 module.

The order in which the ePWM modules are connected may differ from what is shown in Figure 3-1. See Section 3.2.2.3.3 for the synchronization scheme for a particular device. Each ePWM module consists of eight submodules and is connected within a system via the signals shown in Figure 3-2.

CTRIP Output

PIE

ADC



Figure 3-3 shows more internal details of a single ePWM module. The main signals used by the ePWM module are:

Digital Compare (DC) module

# PWM output signals (EPWMxA and EPWMxB)

The PWM output signals are made available external to the device through the GPIO peripheral described in the system control and interrupts guide for your device.

## Trip-zone signals (TZ1 to TZ6)

These input signals alert the ePWM module of fault conditions external to the ePWM module. Each module on a device can be configured to either use or ignore any of the trip-zone signals. The  $\overline{121}$  to TZ3 trip-zone signals can be configured as asynchronous inputs through the GPIO peripheral. TZ4 is connected to an inverted EQEP1 error signal (EQEP1ERR) from the EQEP1 module (for those devices with an EQEP1 module). TZ5 is connected to the system clock fail logic, and TZ6 is connected to the EMUSTOP output from the CPU. This allows you to configure a trip action when the clock fails or the CPU halts.

# Time-base synchronization input (EPWMxSYNCI) and output (EPWMxSYNCO) signals

The synchronization signals daisy chain the ePWM modules together. Each module can be configured to either use or ignore its synchronization input. The clock synchronization input and output signal are brought out to pins only for ePWM1 (ePWM module #1). The synchronization output for ePWM1 (EPWM1SYNCO) is also connected to the SYNCI of the first enhanced capture module (eCAP1).

#### ADC start-of-conversion signals (EPWMxSOCA and EPWMxSOCB)

Each ePWM module has two ADC start of conversion signals. Any ePWM module can trigger a start of conversion. Which event triggers the start of conversion is configured in the Event-Trigger submodule of the ePWM.

# Comparator Trip (CTRIP) Output Subsystem

The comparator trip (CTRIP) output subsystem combines the comparator trip signals by motor or PFC subsystems. Individual CTRIP signals are enabled or disabled through the CTRIPxxOCTL registers. The combined CTRIP and CTRIPOUT signals are then dispatched to downstream EPWM and GPIO modules.

#### **Peripheral Bus**

The peripheral bus is 32-bits wide and allows both 16-bit and 32-bit writes to the ePWM register file.





Figure 3-3. ePWM Submodules and Critical Internal Signal Interconnects

- A These events are generated by the type 1 ePWM digital compare (DC) submodule based on the levels of the CTRIPxx and TZ signals.
- B This signal exists only on devices with in eQEP1 module.

Figure 3-3 also shows the key internal submodule interconnect signals. Each submodule is described in detail in its respective section.

# 3.1.2 Register Mapping

The complete ePWM module control and status register set is grouped by submodule as shown in Table 3-1. Each register set is duplicated for each instance of the ePWM module. The start address for each ePWM register file instance on a device is specified in the appropriate data manual.



Introduction

www.ti.com

## Table 3-1. ePWM Module Control and Status Register Set Grouped by Submodule

| Name      | Offset           | Size<br>(x16) | Shadow | EALLOW | Description                                             |
|-----------|------------------|---------------|--------|--------|---------------------------------------------------------|
|           |                  |               |        |        | Time-Base Submodule Registers                           |
| TBCTL     | 0x0000           | 1             | No     |        | Time-Base Control Register                              |
| TBSTS     | 0x0001           | 1             | No     |        | Time-Base Status Register                               |
| TBPHS     | 0x0003           | 1             | No     |        | Time-Base Phase Register                                |
| TBCTR     | 0x0004           | 1             | No     |        | Time-Base Counter Register                              |
| TBPRD     | 0x0005           | 1             | Yes    |        | Time-Base Period Register                               |
|           |                  |               |        |        | Counter-Compare Submodule Registers                     |
| CMPCTL    | 0x0007           | 1             | No     |        | Counter-Compare Control Register                        |
| СМРА      | 0x0009           | 1             | Yes    |        | Counter-Compare A Register                              |
| СМРВ      | 0x000A           | 1             | Yes    |        | Counter-Compare B Register                              |
|           |                  |               |        |        | Action-Qualifier Submodule Registers                    |
| AQCTLA    | 0x000B           | 1             | No     |        | Action-Qualifier Control Register for Output A (EPWMxA) |
| AQCTLB    | 0x000C           | 1             | No     |        | Action-Qualifier Control Register for Output B (EPWMxB) |
| AQSFRC    | 0x000D           | 1             | No     |        | Action-Qualifier Software Force Register                |
| AQCSFRC   | 0x000E           | 1             | Yes    |        | Action-Qualifier Continuous S/W Force Register Set      |
|           |                  |               |        |        | Dead-Band Generator Submodule Registers                 |
| DBCTL     | 0x000F           | 1             | No     |        | Dead-Band Generator Control Register                    |
| DBRED     | 0x0010           | 1             | No     |        | Dead-Band Generator Rising Edge Delay Count Register    |
| DBFED     | 0x0011           | 1             | No     |        | Dead-Band Generator Falling Edge Delay Count Register   |
|           |                  |               |        |        | Trip-Zone Submodule Registers                           |
| TZSEL     | 0x0012           | 1             |        | Yes    | Trip-Zone Select Register                               |
| TZDCSEL   | 0x0013           | 1             |        | Yes    | Trip Zone Digital Compare Select Register               |
| TZCTL     | 0x0014           | 1             |        | Yes    | Trip-Zone Control Register <sup>(2)</sup>               |
| TZEINT    | 0x0015           | 1             |        | Yes    | Trip-Zone Enable Interrupt Register <sup>(2)</sup>      |
| TZFLG     | 0x0016           | 1             |        |        | Trip-Zone Flag Register <sup>(2)</sup>                  |
| TZCLR     | 0x0017           | 1             |        | Yes    | Trip-Zone Clear Register <sup>(2)</sup>                 |
| TZFRC     | 0x0018           | 1             |        | Yes    | Trip-Zone Force Register <sup>(2)</sup>                 |
|           |                  |               |        |        | Event-Trigger Submodule Registers                       |
| ETSEL     | 0x0019           | 1             |        |        | Event-Trigger Selection Register                        |
| ETPS      | 0x001A           | 1             |        |        | Event-Trigger Pre-Scale Register                        |
| ETFLG     | 0x001B           | 1             |        |        | Event-Trigger Flag Register                             |
| ETCLR     | 0x001C           | 1             |        |        | Event-Trigger Clear Register                            |
| ETFRC     | 0x001D           | 1             |        |        | Event-Trigger Force Register                            |
|           |                  |               |        |        | PWM-Chopper Submodule Registers                         |
| PCCTL     | 0x001E           | 1             |        |        | PWM-Chopper Control Register                            |
|           |                  | -             |        |        | Time-Base Submodule Mirror Registers                    |
| TBPRDM    | 0x002B           | 1             | Writes |        | Time Base Period Register Mirror                        |
| CMPAM     | 0x002D           | 1             | Writes |        | Compare A Register Mirror                               |
|           | 0.00022          |               |        |        | Digital Compare Event Registers                         |
| DCTRIPSEL | 0x0030           | 1             |        | Yes    | Digital Compare Trip Select Register                    |
|           | 0x0030           | 1             |        | Yes    | Digital Compare A Control Register                      |
| DCACTL    | 0x0031<br>0x0032 | 1             |        | Yes    | Digital Compare B Control Register                      |
| DCFCTL    | 0x0032           | 1             |        | Yes    | Digital Compare Dicontrol Register                      |
| DCCAPCTL  | 0x0033           | 1             |        | Yes    | Digital Compare Lance Control Register                  |
| DCFOFFSET | 0x0034           | 1             | Writes | 100    | Digital Compare Filter Offset Register                  |

<sup>(1)</sup> Locations not shown are reserved.

<sup>(2)</sup> EALLOW protected registers as described in the specific device version of the *System Control and Interrupts Reference Guide* listed in .

## Table 3-1. ePWM Module Control and Status Register Set Grouped by Submodule (continued)

| Name         | Offset | Size<br>(x16) | Shadow | EALLOW | Description                                    |
|--------------|--------|---------------|--------|--------|------------------------------------------------|
| DCFOFFSETCNT | 0x0036 | 1             |        |        | Digital Compare Filter Offset Counter Register |
| DCFWINDOW    | 0x0037 | 1             |        |        | Digital Compare Filter Window Register         |
| DCFWINDOWCNT | 0x0038 | 1             |        |        | Digital Compare Filter Window Counter Register |
| DCCAP        | 0x0039 | 1             | Yes    |        | Digital Compare Counter Capture Register       |

The CMPA and TBPRD registers are mirrored in the register map (Mirror registers include an "-M" suffix - CMPAM and TBPRDM). Note in the tables below, that in both Immediate mode and Shadow mode, reads from these mirror registers result in the active value of the register or a TI internal test value.

In Immediate Mode:

| Register | Offset | Write  | Read   | Register | Offset | Write  | Read   |
|----------|--------|--------|--------|----------|--------|--------|--------|
| TBPRD    | 0x05   | Active | Active | TBPRDM   | 0x2B   | Active | Active |
| CMPA     | 0x09   | Active | Active | CMPAM    | 0x2D   | Active | Active |

In Shadow Mode:

| Register | Offset | Write  | Read   | Register | Offset | Write  | Read   |
|----------|--------|--------|--------|----------|--------|--------|--------|
| TBPRD    | 0x05   | Shadow | Shadow | TBPRDM   | 0x2B   | Shadow | Active |
| CMPA     | 0x09   | Shadow | Shadow | CMPAM    | 0x2D   | Shadow | Active |

# 3.2 ePWM Submodules

Eight submodules are included in every ePWM peripheral. Each of these submodules performs specific tasks that can be configured by software.

# 3.2.1 Overview

Table 3-2 lists the eight key submodules together with a list of their main configuration parameters. For example, if you need to adjust or control the duty cycle of a PWM waveform, then you should see the counter-compare submodule in Section 3.2.3 for relevant details.

| Submodule             | Configuration Parameter or Option                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Time-base (TB)        | <ul> <li>Scale the time-base clock (TBCLK) relative to the system clock (SYSCLKOUT).</li> <li>Configure the PWM time-base counter (TBCTR) frequency or period.</li> <li>Set the mode for the time-base counter: <ul> <li>count-up mode: used for asymmetric PWM</li> <li>count-down mode: used for asymmetric PWM</li> <li>count-up-and-down mode: used for symmetric PWM</li> </ul> </li> <li>Configure the time-base phase relative to another ePWM module.</li> <li>Synchronize the time-base counter between modules through hardware or software.</li> <li>Configure the direction (up or down) of the time-base counter after a synchronization event.</li> <li>Configure how the time-base counter will behave when the device is halted by an emulator.</li> <li>Specify the source for the synchronization output of the ePWM module: <ul> <li>Synchronization input signal</li> <li>Time-base counter equal to zero</li> </ul> </li> </ul> |
|                       | <ul> <li>Time-base counter equal to counter-compare B (CMPB)</li> <li>No output synchronization signal generated.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Counter-compare (CC)  | <ul> <li>Specify the PWM duty cycle for output EPWMxA and/or output EPWMxB</li> <li>Specify the time at which switching events occur on the EPWMxA or EPWMxB output</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Action-qualifier (AQ) | <ul> <li>Specify the type of action taken when a time-base or counter-compare submodule event occurs:         <ul> <li>No action taken</li> <li>Output EPWMxA and/or EPWMxB switched high</li> <li>Output EPWMxA and/or EPWMxB switched low</li> <li>Output EPWMxA and/or EPWMxB toggled</li> </ul> </li> <li>Force the PWM output state through software control</li> <li>Configure and control the PWM dead-band through software</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Dead-band (DB)        | <ul> <li>Control of traditional complementary dead-band relationship between upper and lower switches</li> <li>Specify the output rising-edge-delay value</li> <li>Specify the output falling-edge delay value</li> <li>Bypass the dead-band module entirely. In this case the PWM waveform is passed through without modification.</li> <li>Option to enable half-cycle clocking for double resolution.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| PWM-chopper (PC)      | <ul> <li>Create a chopping (carrier) frequency.</li> <li>Pulse width of the first pulse in the chopped pulse train.</li> <li>Duty cycle of the second and subsequent pulses.</li> <li>Bypass the PWM-chopper module entirely. In this case the PWM waveform is passed through without modification.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### **Table 3-2. Submodule Configuration Parameters**

Ţexas

TRUMENTS

| Submodule            | Configuration Parameter or Option                                                                                                   |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Trip-zone (TZ)       | <ul> <li>Configure the ePWM module to react to one, all, or none of the trip-zone signals or digital<br/>compare events.</li> </ul> |
|                      | <ul> <li>Specify the tripping action taken when a fault occurs:</li> </ul>                                                          |
|                      | <ul> <li>Force EPWMxA and/or EPWMxB high</li> </ul>                                                                                 |
|                      | <ul> <li>Force EPWMxA and/or EPWMxB low</li> </ul>                                                                                  |
|                      | <ul> <li>Force EPWMxA and/or EPWMxB to a high-impedance state</li> </ul>                                                            |
|                      | <ul> <li>Configure EPWMxA and/or EPWMxB to ignore any trip condition.</li> </ul>                                                    |
|                      | <ul> <li>Configure how often the ePWM will react to each trip-zone signal:</li> </ul>                                               |
|                      | – One-shot                                                                                                                          |
|                      | <ul> <li>Cycle-by-cycle</li> </ul>                                                                                                  |
|                      | <ul> <li>Enable the trip-zone to initiate an interrupt.</li> </ul>                                                                  |
|                      | Bypass the trip-zone module entirely.                                                                                               |
| Event-trigger (ET)   | <ul> <li>Enable the ePWM events that will trigger an interrupt.</li> </ul>                                                          |
|                      | <ul> <li>Enable ePWM events that will trigger an ADC start-of-conversion event.</li> </ul>                                          |
|                      | <ul> <li>Specify the rate at which events cause triggers (every occurrence or every second or third occurrence)</li> </ul>          |
|                      | Poll, set, or clear event flags                                                                                                     |
| Digital-compare (DC) | <ul> <li>Enables comparator (COMP) module outputs and trip zone signals to create events and filtered<br/>events</li> </ul>         |
|                      | <ul> <li>Specify event-filtering options to capture TBCTR counter or generate blanking window</li> </ul>                            |

| Table 3-2. Submodule Configuration Pa | arameters (continued) |
|---------------------------------------|-----------------------|
|---------------------------------------|-----------------------|

Code examples are provided in the remainder of this document that show how to implement various ePWM module configurations. These examples use the constant definitions in the device *EPwm\_defines.h* file in the device-specific header file and peripheral examples software package.



# 3.2.2 Time-Base (TB) Submodule

Each ePWM module has its own time-base submodule that determines all of the event timing for the ePWM module. Built-in synchronization logic allows the time-base of multiple ePWM modules to work together as a single system. Figure 3-4 illustrates the time-base module's place within the ePWM.





## 3.2.2.1 Purpose of the Time-Base Submodule

You can configure the time-base submodule for the following:

- Specify the ePWM time-base counter (TBCTR) frequency or period to control how often events occur.
- Manage time-base synchronization with other ePWM modules.
- · Maintain a phase relationship with other ePWM modules.
- Set the time-base counter to count-up, count-down, or count-up-and-down mode.
- Generate the following events:
  - CTR = PRD: Time-base counter equal to the specified period (TBCTR = TBPRD) .
  - CTR = Zero: Time-base counter equal to zero (TBCTR = 0x0000).
- Configure the rate of the time-base clock; a prescaled version of the CPU system clock (SYSCLKOUT). This allows the time-base counter to increment/decrement at a slower rate.

#### ePWM Submodules

# 3.2.2.2 Controlling and Monitoring the Time-base Submodule

Table 3-3 shows the registers used to control and monitor the time-base submodule.

| Table 5-5. Time-base Submodule Registers |                |          |                            |  |
|------------------------------------------|----------------|----------|----------------------------|--|
| Register                                 | Address offset | Shadowed | Description                |  |
| TBCTL                                    | 0x0000         | No       | Time-Base Control Register |  |
| TBSTS                                    | 0x0001         | No       | Time-Base Status Register  |  |
| TBPHS                                    | 0x0003         | No       | Time-Base Phase Register   |  |
| TBCTR                                    | 0x0004         | No       | Time-Base Counter Register |  |
| TBPRD                                    | 0x0005         | Yes      | Time-Base Period Register  |  |

| Table 3-3. | Time-Base | Submodule | Registers |
|------------|-----------|-----------|-----------|
|------------|-----------|-----------|-----------|

The block diagram in Figure 3-5 shows the critical signals and registers of the time-base submodule. Table 3-4 provides descriptions of the key signals associated with the time-base submodule.



Figure 3-5. Time-Base Submodule Signals and Registers

A. These signals are generated by the digital compare (DC) submodule.

| Table 3-4 | Key | Time-Base | Signals |
|-----------|-----|-----------|---------|
|-----------|-----|-----------|---------|

| Signal     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EPWMxSYNCI | Time-base synchronization input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | Input pulse used to synchronize the time-base counter with the counter of ePWM module earlier in the synchronization chain. An ePWM peripheral can be configured to use or ignore this signal. For the first ePWM module (EPWM1) this signal comes from a device pin. For subsequent ePWM modules this signal is passed from another ePWM peripheral. For example, EPWM2SYNCI is generated by the ePWM1 peripheral, EPWM3SYNCI is generated by ePWM2 and so forth. See Section 3.2.2.3.3 for information on the synchronization order of a particular device. |

SPRUHE5B-November 2012-Revised April 2013 Submit Documentation Feedback



ePWM Submodules

| Signal     | Description                                                                                                                                                                                    |  |  |  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| EPWMxSYNCO | Time-base synchronization output.                                                                                                                                                              |  |  |  |
|            | This output pulse is used to synchronize the counter of an ePWM module later in the synchronization chain.<br>The ePWM module generates this signal from one of three event sources:           |  |  |  |
|            | 1. EPWMxSYNCI (Synchronization input pulse)                                                                                                                                                    |  |  |  |
|            | 2. CTR = Zero: The time-base counter equal to zero (TBCTR = 0x0000).                                                                                                                           |  |  |  |
|            | 3. CTR = CMPB: The time-base counter equal to the counter-compare B (TBCTR = CMPB) register.                                                                                                   |  |  |  |
| CTR = PRD  | Time-base counter equal to the specified period.                                                                                                                                               |  |  |  |
|            | This signal is generated whenever the counter value is equal to the active period register value. That is when TBCTR = TBPRD.                                                                  |  |  |  |
| CTR = Zero | Time-base counter equal to zero                                                                                                                                                                |  |  |  |
|            | This signal is generated whenever the counter value is zero. That is when TBCTR equals 0x0000.                                                                                                 |  |  |  |
| CTR = CMPB | Time-base counter equal to active counter-compare B register (TBCTR = CMPB).                                                                                                                   |  |  |  |
|            | This event is generated by the counter-compare submodule and used by the synchronization out logic                                                                                             |  |  |  |
| CTR_dir    | Time-base counter direction.                                                                                                                                                                   |  |  |  |
|            | Indicates the current direction of the ePWM's time-base counter. This signal is high when the counter is<br>increasing and low when it is decreasing.                                          |  |  |  |
| CTR_max    | Time-base counter equal max value. (TBCTR = 0xFFFF)                                                                                                                                            |  |  |  |
|            | Generated event when the TBCTR value reaches its maximum value. This signal is only used only as a status bit                                                                                  |  |  |  |
| TBCLK      | Time-base clock.                                                                                                                                                                               |  |  |  |
|            | This is a prescaled version of the system clock (SYSCLKOUT) and is used by all submodules within the ePWM. This clock determines the rate at which time-base counter increments or decrements. |  |  |  |

#### Table 3-4. Key Time-Base Signals (continued)

# 3.2.2.3 Calculating PWM Period and Frequency

The frequency of PWM events is controlled by the time-base period (TBPRD) register and the mode of the time-base counter. Figure 3-6 shows the period ( $T_{pwm}$ ) and frequency ( $F_{pwm}$ ) relationships for the up-count, down-count, and up-down-count time-base counter modes when when the period is set to 4 (TBPRD = 4). The time increment for each step is defined by the time-base clock (TBCLK) which is a prescaled version of the system clock (SYSCLKOUT).

The time-base counter has three modes of operation selected by the time-base control register (TBCTL):

#### • Up-Down-Count Mode:

In up-down-count mode, the time-base counter starts from zero and increments until the period (TBPRD) value is reached. When the period value is reached, the time-base counter then decrements until it reaches zero. At this point the counter repeats the pattern and begins to increment.

#### Up-Count Mode:

In this mode, the time-base counter starts from zero and increments until it reaches the value in the period register (TBPRD). When the period value is reached, the time-base counter resets to zero and begins to increment once again.

#### • Down-Count Mode:

In down-count mode, the time-base counter starts from the period (TBPRD) value and decrements until it reaches zero. When it reaches zero, the time-base counter is reset to the period value and it begins to decrement once again.



# Figure 3-6. Time-Base Frequency and Period

#### 3.2.2.3.1 Time-Base Period Shadow Register

The time-base period register (TBPRD) has a shadow register. Shadowing allows the register update to be synchronized with the hardware. The following definitions are used to describe all shadow registers in the ePWM module:

#### Active Register

The active register controls the hardware and is responsible for actions that the hardware causes or invokes.

#### Shadow Register

The shadow register buffers or provides a temporary holding location for the active register. It has no direct effect on any control hardware. At a strategic point in time the shadow register's content is transferred to the active register. This prevents corruption or spurious operation due to the register being asynchronously modified by software.

The memory address of the shadow period register is the same as the active register. Which register is written to or read from is determined by the TBCTL[PRDLD] bit. This bit enables and disables the TBPRD shadow register as follows:

#### • Time-Base Period Shadow Mode:

The TBPRD shadow register is enabled when TBCTL[PRDLD] = 0. Reads from and writes to the TBPRD memory address go to the shadow register. The shadow register contents are transferred to the active register (TBPRD (Active)  $\leftarrow$  TBPRD (shadow)) when the time-base counter equals zero (TBCTR = 0x0000). By default the TBPRD shadow register is enabled.

#### • Time-Base Period Immediate Load Mode:

If immediate load mode is selected (TBCTL[PRDLD] = 1), then a read from or a write to the TBPRD



memory address goes directly to the active register.

#### 3.2.2.3.2 Time-Base Clock Synchronization

The TBCLKSYNC bit in the peripheral clock enable registers allows all users to globally synchronize all enabled ePWM modules to the time-base clock (TBCLK). When set, all enabled ePWM module clocks are started with the first rising edge of TBCLK aligned. For perfectly synchronized TBCLKs, the prescalers for each ePWM module must be set identically.

The proper procedure for enabling ePWM clocks is as follows:

- 1. Enable ePWM module clocks in the PCLKCRx register
- 2. Set TBCLKSYNC= 0
- 3. Configure ePWM modules
- 4. Set TBCLKSYNC=1

## 3.2.2.3.3 Time-Base Counter Synchronization

A time-base synchronization scheme connects all of the ePWM modules on a device. Each ePWM module has a synchronization input (EPWMxSYNCI) and a synchronization output (EPWMxSYNCO). The input synchronization for the first instance (ePWM1) comes from an external pin. The possible synchronization connections for the remaining ePWM modules is shown in Figure 3-7.

## Figure 3-7. Time-Base Counter Synchronization Scheme 1





Each ePWM module can be configured to use or ignore the synchronization input. If the TBCTL[PHSEN] bit is set, then the time-base counter (TBCTR) of the ePWM module will be automatically loaded with the phase register (TBPHS) contents when one of the following conditions occur:

## • EPWMxSYNCI: Synchronization Input Pulse:

The value of the phase register is loaded into the counter register when an input synchronization pulse is detected (TBPHS  $\rightarrow$  TBCTR). This operation occurs on the next valid time-base clock (TBCLK) edge.

The delay from internal master module to slave modules is given by:

- if ( TBCLK = SYSCLKOUT): 2 x SYSCLKOUT
- if ( TBCLK != SYSCLKOUT):1 TBCLK

## • Software Forced Synchronization Pulse:

Writing a 1 to the TBCTL[SWFSYNC] control bit invokes a software forced synchronization. This pulse is ORed with the synchronization input signal, and therefore has the same effect as a pulse on EPWMxSYNCI.

#### • Digital Compare Event Synchronization Pulse:

DCAEVT1 and DCBEVT1 digital compare events can be configured to generate synchronization pulses which have the same affect as EPWMxSYNCI.

This feature enables the ePWM module to be automatically synchronized to the time base of another ePWM module. Lead or lag phase control can be added to the waveforms generated by different ePWM modules to synchronize them. In up-down-count mode, the TBCTL[PSHDIR] bit configures the direction of the time-base counter immediately after a synchronization event. The new direction is independent of the direction prior to the synchronization event. The PHSDIR bit is ignored in count-up or count-down modes. See Figure 3-8 through Figure 3-11 for examples.

Clearing the TBCTL[PHSEN] bit configures the ePWM to ignore the synchronization input pulse. The synchronization pulse can still be allowed to flow-through to the EPWMxSYNCO and be used to synchronize other ePWM modules. In this way, you can set up a master time-base (for example, ePWM1) and downstream modules (ePWM2 - ePWMx) may elect to run in synchronization with the master. See the Application to Power Topologies Section 3.3 for more details on synchronization strategies.

# 3.2.2.4 Phase Locking the Time-Base Clocks of Multiple ePWM Modules

The TBCLKSYNC bit can be used to globally synchronize the time-base clocks of all enabled ePWM modules on a device. This bit is part of the device's clock enable registers and is described in the specific device version of the *System Control and Interrupts Reference Guide* listed in . When TBCLKSYNC = 0, the time-base clock of all ePWM modules is stopped (default). When TBCLKSYNC = 1, all ePWM time-base clocks are started with the rising edge of TBCLK aligned. For perfectly synchronized TBCLKs, the prescaler bits in the TBCTL register of each ePWM module must be set identically. The proper procedure for enabling the ePWM clocks is as follows:

- 1. Enable the individual ePWM module clocks. This is described in the specific device version of the *System Control and Interrupts Reference Guide* listed in .
- 2. Set TBCLKSYNC = 0. This will stop the time-base clock within any enabled ePWM module.
- 3. Configure the prescaler values and desired ePWM modes.
- 4. Set TBCLKSYNC = 1.

### 3.2.2.5 Time-base Counter Modes and Timing Waveforms

The time-base counter operates in one of four modes:

- Up-count mode which is asymmetrical.
- Down-count mode which is asymmetrical.
- Up-down-count which is symmetrical
- Frozen where the time-base counter is held constant at the current value

To illustrate the operation of the first three modes, the following timing diagrams show when events are generated and how the time-base responds to an EPWMxSYNCI signal.



Figure 3-8. Time-Base Up-Count Mode Waveforms















#### Figure 3-11. Time-Base Up-Down Count Waveforms, TBCTL[PHSDIR = 1] Count Up On Synchronization Event

# 3.2.3 Counter-Compare (CC) Submodule

Figure 3-12 illustrates the counter-compare submodule within the ePWM.

Figure 3-12. Counter-Compare Submodule



Figure 3-13 shows the basic structure of the counter-compare submodule.



## 3.2.3.1 Purpose of the Counter-Compare Submodule

The counter-compare submodule takes as input the time-base counter value. This value is continuously compared to the counter-compare A (CMPA) and counter-compare B (CMPB) registers. When the time-base counter is equal to one of the compare registers, the counter-compare unit generates an appropriate event.

The counter-compare:

- Generates events based on programmable time stamps using the CMPA and CMPB registers
  - CTR = CMPA: Time-base counter equals counter-compare A register (TBCTR = CMPA).
  - CTR = CMPB: Time-base counter equals counter-compare B register (TBCTR = CMPB)
- Controls the PWM duty cycle if the action-qualifier submodule is configured appropriately
- Shadows new compare values to prevent corruption or glitches during the active PWM cycle

# 3.2.3.2 Controlling and Monitoring the Counter-Compare Submodule

The counter-compare submodule operation is controlled and monitored by the registers shown in Table 3-5:

| Register Name | Address Offset | Shadowed | Description                       |
|---------------|----------------|----------|-----------------------------------|
| CMPCTL        | 0x0007         | No       | Counter-Compare Control Register. |
| CMPA          | 0x0009         | Yes      | Counter-Compare A Register        |
| СМРВ          | 0x000A         | Yes      | Counter-Compare B Register        |
| CMPAM         | 0x002D         | Writes   | Counter-compare A mirror Register |





## Figure 3-13. Detailed View of the Counter-Compare Submodule

The key signals associated with the counter-compare submodule are described in Table 3-6.



| Table 5-0. Counter-Compare Cubinodule Rey Olghals |                                                                                                                                 |                    |  |
|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------|--|
| Signal                                            | Description of Event                                                                                                            | Registers Compared |  |
| CTR = CMPA                                        | Time-base counter equal to the active counter-compare A value                                                                   | TBCTR = CMPA       |  |
| CTR = CMPB                                        | Time-base counter equal to the active counter-compare B value                                                                   | TBCTR = CMPB       |  |
| CTR = PRD                                         | Time-base counter equal to the active period.<br>Used to load active counter-compare A and B registers from the shadow register | TBCTR = TBPRD      |  |
| CTR = ZERO                                        | Time-base counter equal to zero.<br>Used to load active counter-compare A and B registers from the shadow register              | TBCTR = 0x0000     |  |

 Table 3-6. Counter-Compare Submodule Key Signals

# 3.2.3.3 Operational Highlights for the Counter-Compare Submodule

The counter-compare submodule is responsible for generating two independent compare events based on two compare registers:

- 1. CTR = CMPA: Time-base counter equal to counter-compare A register (TBCTR = CMPA).
- 2. CTR = CMPB: Time-base counter equal to counter-compare B register (TBCTR = CMPB).

For up-count or down-count mode, each event occurs only once per cycle. For up-down-count mode each event occurs twice per cycle if the compare value is between 0x0000-TBPRD and once per cycle if the compare value is equal to 0x0000 or equal to TBPRD. These events are fed into the action-qualifier submodule where they are qualified by the counter direction and converted into actions if enabled. Refer to Section 3.2.4.1 for more details.

The counter-compare registers CMPA and CMPB each have an associated shadow register. Shadowing provides a way to keep updates to the registers synchronized with the hardware. When shadowing is used, updates to the active registers only occur at strategic points. This prevents corruption or spurious operation due to the register being asynchronously modified by software. The memory address of the active register and the shadow register is identical. Which register is written to or read from is determined by the CMPCTL[SHDWAMODE] and CMPCTL[SHDWBMODE] bits. These bits enable and disable the CMPA shadow register and CMPB shadow register respectively. The behavior of the two load modes is described below:

#### Shadow Mode:

The shadow mode for the CMPA is enabled by clearing the CMPCTL[SHDWAMODE] bit and the shadow register for CMPB is enabled by clearing the CMPCTL[SHDWBMODE] bit. Shadow mode is enabled by default for both CMPA and CMPB.

If the shadow register is enabled then the content of the shadow register is transferred to the active register on one of the following events as specified by the CMPCTL[LOADAMODE] and CMPCTL[LOADBMODE] register bits:

- CTR = PRD: Time-base counter equal to the period (TBCTR = TBPRD).
- CTR = Zero: Time-base counter equal to zero (TBCTR = 0x0000)
- Both CTR = PRD and CTR = Zero

Only the active register contents are used by the counter-compare submodule to generate events to be sent to the action-qualifier.

#### Immediate Load Mode:

If immediate load mode is selected (that is, TBCTL[SHADWAMODE] = 1 or TBCTL[SHADWBMODE] = 1), then a read from or a write to the register will go directly to the active register.

# 3.2.3.4 Count Mode Timing Waveforms

The counter-compare module can generate compare events in all three count modes:

- Up-count mode: used to generate an asymmetrical PWM waveform.
- Down-count mode: used to generate an asymmetrical PWM waveform.
- Up-down-count mode: used to generate a symmetrical PWM waveform.

To best illustrate the operation of the first three modes, the timing diagrams in Figure 3-14 through Figure 3-17 show when events are generated and how the EPWMxSYNCI signal interacts.





NOTE: An EPWMxSYNCI external synchronization event can cause a discontinuity in the TBCTR count sequence. This can lead to a compare event being skipped. This skipping is considered normal operation and must be taken into account.











# Figure 3-16. Counter-Compare Events In Up-Down-Count Mode, TBCTL[PHSDIR = 0] Count Down On Synchronization Event





# 3.2.4 Action-Qualifier (AQ) Submodule

Figure 3-18 shows the action-qualifier (AQ) submodule (see shaded block) in the ePWM system.



Figure 3-18. Action-Qualifier Submodule

The action-qualifier submodule has the most important role in waveform construction and PWM generation. It decides which events are converted into various action types, thereby producing the required switched waveforms at the EPWMxA and EPWMxB outputs.

# 3.2.4.1 Purpose of the Action-Qualifier Submodule

The action-qualifier submodule is responsible for the following:

- Qualifying and generating actions (set, clear, toggle) based on the following events:
- CTR = PRD: Time-base counter equal to the period (TBCTR = TBPRD).
- CTR = Zero: Time-base counter equal to zero (TBCTR = 0x0000)
- CTR = CMPA: Time-base counter equal to the counter-compare A register (TBCTR = CMPA)
- CTR = CMPB: Time-base counter equal to the counter-compare B register (TBCTR = CMPB)
- Managing priority when these events occur concurrently
- Providing independent control of events when the time-base counter is increasing and when it is decreasing.

# 3.2.4.2 Action-Qualifier Submodule Control and Status Register Definitions

The action-qualifier submodule operation is controlled and monitored via the registers in Table 3-7.

| Register<br>Name | Address offset | Shadowed | Description                                             |
|------------------|----------------|----------|---------------------------------------------------------|
| AQCTLA           | 0x000B         | No       | Action-Qualifier Control Register For Output A (EPWMxA) |
| AQCTLB           | 0x000C         | No       | Action-Qualifier Control Register For Output B (EPWMxB) |
| AQSFRC           | 0x000D         | No       | Action-Qualifier Software Force Register                |
| AQCSFRC          | 0x000E         | Yes      | Action-Qualifier Continuous Software Force              |

#### Table 3-7. Action-Qualifier Submodule Registers



The action-qualifier submodule is based on event-driven logic. It can be thought of as a programmable cross switch with events at the input and actions at the output, all of which are software controlled via the set of registers shown in Table 3-7.





For convenience, the possible input events are summarized again in Table 3-8.

| Signal                | Description                                      | Registers Compared |
|-----------------------|--------------------------------------------------|--------------------|
| CTR = PRD             | Time-base counter equal to the period value      | TBCTR = TBPRD      |
| CTR = Zero            | Time-base counter equal to zero                  | TBCTR = 0x0000     |
| CTR = CMPA            | Time-base counter equal to the counter-compare A | TBCTR = CMPA       |
| CTR = CMPB            | Time-base counter equal to the counter-compare B | TBCTR = CMPB       |
| Software forced event | Asynchronous event initiated by software         |                    |

The software forced action is a useful asynchronous event. This control is handled by registers AQSFRC and AQCSFRC.

The action-qualifier submodule controls how the two outputs EPWMxA and EPWMxB behave when a particular event occurs. The event inputs to the action-qualifier submodule are further qualified by the counter direction (up or down). This allows for independent action on outputs on both the count-up and count-down phases.

The possible actions imposed on outputs EPWMxA and EPWMxB are:

• Set High:

Set output EPWMxA or EPWMxB to a high level.

• Clear Low:

Set output EPWMxA or EPWMxB to a low level.

Toggle:

If EPWMxA or EPWMxB is currently pulled high, then pull the output low. If EPWMxA or EPWMxB is currently pulled low, then pull the output high.

• Do Nothing:

Keep outputs EPWMxA and EPWMxB at same level as currently set. Although the "Do Nothing" option prevents an event from causing an action on the EPWMxA and EPWMxB outputs, this event can still trigger interrupts and ADC start of conversion. See the Event-trigger Submodule description in Section 3.2.8 for details.



Actions are specified independently for either output (EPWMxA or EPWMxB). Any or all events can be configured to generate actions on a given output. For example, both CTR = CMPA and CTR = CMPB can operate on output EPWMxA. All qualifier actions are configured via the control registers found at the end of this section.

For clarity, the drawings in this document use a set of symbolic actions. These symbols are summarized in Figure 3-20. Each symbol represents an action as a marker in time. Some actions are fixed in time (zero and period) while the CMPA and CMPB actions are moveable and their time positions are programmed via the counter-compare A and B registers, respectively. To turn off or disable an action, use the "Do Nothing option"; it is the default at reset.

| S/W                              | TB Counter equals: |                         |                        | Actions |            |
|----------------------------------|--------------------|-------------------------|------------------------|---------|------------|
| force                            | Zero               | Comp<br>A               | Comp<br>B              | Period  |            |
| $\stackrel{\mathrm{sw}}{\times}$ | Z<br>×             | $\stackrel{CA}{\times}$ | $\stackrel{CB}{	imes}$ | P×      | Do Nothing |
| S₩                               | Z                  | CA                      | CB                     | P       | Clear Low  |
| ➡                                | ↓                  | ↓                       | ↓                      | ↓       |            |
| sw                               | Z                  | CA                      | CB                     | P       | Set High   |
| ♠                                | t                  | ♠                       | ↑                      | ▲       |            |
| SW                               | Z                  | CA                      | CB                     | P       | Toggle     |
| T                                | T                  | T                       | T                      | T       |            |

## Figure 3-20. Possible Action-Qualifier Actions for EPWMxA and EPWMxB Outputs

## 3.2.4.3 Action-Qualifier Event Priority

It is possible for the ePWM action qualifier to receive more than one event at the same time. In this case events are assigned a priority by the hardware. The general rule is events occurring later in time have a higher priority and software forced events always have the highest priority. The event priority levels for up-down-count mode are shown in Table 3-9. A priority level of 1 is the highest priority and level 7 is the lowest. The priority changes slightly depending on the direction of TBCTR.

| Priority Level | Event If TBCTR is Incrementing<br>TBCTR = Zero up to TBCTR = TBPRD | Event If TBCTR is Decrementing<br>TBCTR = TBPRD down to TBCTR = 1 |
|----------------|--------------------------------------------------------------------|-------------------------------------------------------------------|
| 1 (Highest)    | Software forced event                                              | Software forced event                                             |
| 2              | Counter equals CMPB on up-count (CBU)                              | Counter equals CMPB on down-count (CBD)                           |
| 3              | Counter equals CMPA on up-count (CAU)                              | Counter equals CMPA on down-count (CAD)                           |
| 4              | Counter equals zero                                                | Counter equals period (TBPRD)                                     |
| 5              | Counter equals CMPB on down-count (CBD)                            | Counter equals CMPB on up-count (CBU)                             |
| 6 (Lowest)     | Counter equals CMPA on down-count (CAD)                            | Counter equals CMPA on up-count (CBU)                             |

#### Table 3-9. Action-Qualifier Event Priority for Up-Down-Count Mode

Table 3-10 shows the action-qualifier priority for up-count mode. In this case, the counter direction is always defined as up and thus down-count events will never be taken.

| Priority Level | Event                                   |  |
|----------------|-----------------------------------------|--|
| 1 (Highest)    | Software forced event                   |  |
| 2              | Counter equal to period (TBPRD)         |  |
| 3              | Counter equal to CMPB on up-count (CBU) |  |
| 4              | Counter equal to CMPA on up-count (CAU) |  |
| 5 (Lowest)     | Counter equal to Zero                   |  |

Table 3-11 shows the action-qualifier priority for down-count mode. In this case, the counter direction is always defined as down and thus up-count events will never be taken.

#### Table 3-11. Action-Qualifier Event Priority for Down-Count Mode

| Priority Level | Event                                     |  |
|----------------|-------------------------------------------|--|
| 1 (Highest)    | Software forced event                     |  |
| 2              | Counter equal to Zero                     |  |
| 3              | Counter equal to CMPB on down-count (CBD) |  |
| 4              | Counter equal to CMPA on down-count (CAD) |  |
| 5 (Lowest)     | Counter equal to period (TBPRD)           |  |

It is possible to set the compare value greater than the period. In this case the action will take place as shown in Table 3-12.

|  | Table 3-12 | . Behavior if | CMPA/CMPB | is Greater | than the Period |
|--|------------|---------------|-----------|------------|-----------------|
|--|------------|---------------|-----------|------------|-----------------|

| Counter Mode  | Compare on Up-Count Event<br>CAD/CBD                                                             | Compare on Down-Count Event<br>CAD/CBD |
|---------------|--------------------------------------------------------------------------------------------------|----------------------------------------|
| Up-Count Mode | If CMPA/CMPB $\leq$ TBPRD period, then the event occurs on a compare match (TBCTR=CMPA or CMPB). | Never occurs.                          |
|               | If CMPA/CMPB > TBPRD, then the event will not occur.                                             |                                        |

| Counter Mode          | Compare on Up-Count Event<br>CAD/CBD                                                                            | Compare on Down-Count Event<br>CAD/CBD                                                                          |
|-----------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| Down-Count Mode       | Never occurs.                                                                                                   | If CMPA/CMPB < TBPRD, the event will occur on a compare match (TBCTR=CMPA or CMPB).                             |
|                       |                                                                                                                 | If CMPA/CMPB ≥ TBPRD, the event will occur on a period match (TBCTR=TBPRD).                                     |
| Up-Down-Count<br>Mode | If CMPA/CMPB < TBPRD and the counter is incrementing, the event occurs on a compare match (TBCTR=CMPA or CMPB). | If CMPA/CMPB < TBPRD and the counter is decrementing, the event occurs on a compare match (TBCTR=CMPA or CMPB). |
|                       | If CMPA/CMPB is $\geq$ TBPRD, the event will occur on a period match (TBCTR = TBPRD).                           | If CMPA/CMPB ≥ TBPRD, the event occurs on a<br>period match (TBCTR=TBPRD).                                      |

### Table 3-12. Behavior if CMPA/CMPB is Greater than the Period (continued)

## 3.2.4.4 Waveforms for Common Configurations

**NOTE:** The waveforms in this document show the ePWMs behavior for a static compare register value. In a running system, the active compare registers (CMPA and CMPB) are typically updated from their respective shadow registers once every period. The user specifies when the update will take place; either when the time-base counter reaches zero or when the time-base counter reaches period. There are some cases when the action based on the new value can be delayed by one period or the action based on the old value can take effect for an extra period. Some PWM configurations avoid this situation. These include, but are not limited to, the following:

#### Use up-down-count mode to generate a symmetric PWM:

- If you load CMPA/CMPB on zero, then use CMPA/CMPB values greater than or equal to 1.
- If you load CMPA/CMPB on period, then use CMPA/CMPB values less than or equal to TBPRD-1.

This means there will always be a pulse of at least one TBCLK cycle in a PWM period which, when very short, tend to be ignored by the system.

#### Use up-down-count mode to generate an asymmetric PWM:

 To achieve 50%-0% asymmetric PWM use the following configuration: Load CMPA/CMPB on period and use the period action to clear the PWM and a compare-up action to set the PWM. Modulate the compare value from 0 to TBPRD to achieve 50%-0% PWM duty.

#### When using up-count mode to generate an asymmetric PWM:

• To achieve 0-100% asymmetric PWM use the following configuration: Load CMPA/CMPB on TBPRD. Use the Zero action to set the PWM and a compare-up action to clear the PWM. Modulate the compare value from 0 to TBPRD+1 to achieve 0-100% PWM duty.

See the Using Enhanced Pulse Width Modulator (ePWM) Module for 0-100% Duty Cycle Control Application Report (literature number <u>SPRAAI1</u>). The software configurations described in this application report are not applicable when changing compare registers from a non-zero value to zero. However, they still apply when changing from a compare value of 0 to a non-zero value.

Figure 3-21 shows how a symmetric PWM waveform can be generated using the up-down-count mode of the TBCTR. In this mode 0%-100% DC modulation is achieved by using equal compare matches on the up count and down count portions of the waveform. In the example shown, CMPA is used to make the comparison. When the counter is incrementing the CMPA match will pull the PWM output high. Likewise, when the counter is decrementing the compare match will pull the PWM signal low. When CMPA = 0, the PWM signal is low for the entire period giving the 0% duty waveform. When CMPA = TBPRD, the PWM signal is high achieving 100% duty.



When using this configuration in practice, if you load CMPA/CMPB on zero, then use CMPA/CMPB values greater than or equal to 1. If you load CMPA/CMPB on period, then use CMPA/CMPB values less than or equal to TBPRD-1. This means there will always be a pulse of at least one TBCLK cycle in a PWM period which, when very short, tend to be ignored by the system.





The PWM waveforms in Figure 3-22 through Figure 3-27 show some common action-qualifier configurations. The C-code samples in Example 3-1 through Example 3-6 shows how to configure an ePWM module for each case. Some conventions used in the figures and examples are as follows:

- TBPRD, CMPA, and CMPB refer to the value written in their respective registers. The active register, not the shadow register, is used by the hardware.
- CMPx, refers to either CMPA or CMPB.
- EPWMxA and EPWMxB refer to the output signals from ePWMx
- Up-Down means Count-up-and-down mode, Up means up-count mode and Dwn means down-count mode
- Sym = Symmetric, Asym = Asymmetric



# Figure 3-22. Up, Single Edge Asymmetric Waveform, With Independent Modulation on EPWMxA and EPWMxB—Active High

- A PWM period = (TBPRD + 1) × T<sub>TBCLK</sub>
- B Duty modulation for EPWMxA is set by CMPA, and is active high (that is, high time duty proportional to CMPA).
- C Duty modulation for EPWMxB is set by CMPB and is active high (that is, high time duty proportional to CMPB).
- D The "Do Nothing" actions (X) are shown for completeness, but will not be shown on subsequent diagrams.
- E Actions at zero and period, although appearing to occur concurrently, are actually separated by one TBCLK period. TBCTR wraps from period to 0000.

Example 3-1 contains a code sample showing initialization and run time for the waveforms in Figure 3-22.

#### Example 3-1. Code Sample for Figure 3-22

```
// Initialization Time
// = = = = = = = = = = = = =
                                - - - - - - - -
EPwmlRegs.TBPRD = 600;
                                            // Period = 601 TBCLK counts
EPwmlRegs.CMPA.half.CMPA = 350;
                                            // Compare A = 350 TBCLK counts
EPwmlRegs.CMPB = 200;
                                            // Compare B = 200 TBCLK counts
                                            // Set Phase register to zero
EPwmlReqs.TBPHS = 0;
EPwmlRegs.TBCTR = 0;
                                            // clear TB counter
EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE;
                                            // Phase loading disabled
EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwmlRegs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
                                            // TBCLK = SYSCLK
EPwmlRegs.TBCTL.bit.HSPCLKDIV = TB_DIV1;
EPwmlRegs.TBCTL.bit.CLKDIV = TB_DIV1;
EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR = Zero
EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR = Zero
EPwmlRegs.AQCTLA.bit.ZRO = AQ_SET;
EPwmlRegs.AQCTLA.bit.CAU = AQ_CLEAR;
EPwmlRegs.AQCTLB.bit.ZRO = AQ_SET;
EPwm1Regs.AQCTLB.bit.CBU = AQ_CLEAR;
11
// Run Time
EPwmlRegs.CMPA.half.CMPA = Duty1A;
                                            // adjust duty for output EPWM1A
EPwmlRegs.CMPB = Duty1B;
                                            // adjust duty for output EPWM1B
```





# Figure 3-23. Up, Single Edge Asymmetric Waveform With Independent Modulation on EPWMxA and EPWMxB—Active Low

A PWM period = (TBPRD + 1) ×  $T_{TBCLK}$ 

B Duty modulation for EPWMxA is set by CMPA, and is active low (that is, the low time duty is proportional to CMPA).

C Duty modulation for EPWMxB is set by CMPB and is active low (that is, the low time duty is proportional to CMPB).

D Actions at zero and period, although appearing to occur concurrently, are actually separated by one TBCLK period. TBCTR wraps from period to 0000.

Example 3-2 contains a code sample showing initialization and run time for the waveforms in Figure 3-23.

Texas

www.ti.com

Example 3-2. Code Sample for Figure 3-23

```
// Initialization Time
// = = = = = = = = = = = = =
EPwmlRegs.TBPRD = 600;
                                            // Period = 601 TBCLK counts
EPwmlRegs.CMPA.half.CMPA = 350;
                                            // Compare A = 350 TBCLK counts
EPwmlRegs.CMPB = 200;
                                            // Compare B = 200 TBCLK counts
EPwmlRegs.TBPHS = 0;
                                            // Set Phase register to zero
EPwmlRegs.TBCTR = 0;
                                            // clear TB counter
EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE;
                                            // Phase loading disabled
EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwmlRegs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
                                           // TBCLK = SYSCLKOUT
EPwmlRegs.TBCTL.bit.HSPCLKDIV = TB_DIV1;
EPwmlRegs.TBCTL.bit.CLKDIV = TB_DIV1;
EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on TBCTR = Zero
EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on TBCTR = Zero
EPwmlRegs.AQCTLA.bit.PRD = AQ_CLEAR;
EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
EPwmlRegs.AQCTLB.bit.PRD = AQ_CLEAR;
EPwmlRegs.AQCTLB.bit.CBU = AQ_SET;
11
// Run Time
EPwmlRegs.CMPA.half.CMPA = Duty1A;
                                           // adjust duty for output EPWM1A
EPwmlRegs.CMPB = Duty1B;
                                            // adjust duty for output EPWM1B
```





- A PWM frequency = 1/( (TBPRD + 1 ) ×  $T_{TBCLK}$  )
- B Pulse can be placed anywhere within the PWM cycle (0000 TBPRD)
- C High time duty proportional to (CMPB CMPA)
- D EPWMxB can be used to generate a 50% duty square wave with frequency = � x ( (TBPRD + 1 ) x TBCLK )

Example 3-3 contains a code sample showing initialization and run time for the waveforms Figure 3-24. Use the constant definitions in the device-specific header file.



## Example 3-3. Code Sample for Figure 3-24

```
// Initialization Time
// = = = = = = = = = = = =
EPwmlRegs.TBPRD = 600;
                                            // Period = 601 TBCLK counts
EPwmlRegs.CMPA.half.CMPA = 200;
                                            // Compare A = 200 TBCLK counts
EPwmlRegs.CMPB = 400;
                                            // Compare B = 400 TBCLK counts
EPwmlRegs.TBPHS = 0;
                                            // Set Phase register to zero
EPwmlRegs.TBCTR = 0;
                                            // clear TB counter
EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE;
                                            // Phase loading disabled
EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwm1Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
                                           // TBCLK = SYSCLKOUT
EPwmlRegs.TBCTL.bit.HSPCLKDIV = TB_DIV1;
EPwmlRegs.TBCTL.bit.CLKDIV = TB_DIV1;
EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on TBCTR = Zero
EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on TBCTR = Zero
EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
EPwmlRegs.AQCTLA.bit.CBU = AQ_CLEAR;
EPwmlRegs.AQCTLB.bit.ZRO = AQ_TOGGLE;
11
// Run Time
EPwmlRegs.CMPA.half.CMPA = EdgePosA;
                                          // adjust duty for output EPWM1A only
EPwmlRegs.CMPB = EdgePosB;
```

# Figure 3-25. Up-Down-Count, Dual Edge Symmetric Waveform, With Independent Modulation on EPWMxA and EPWMxB — Active Low



- A PWM period = 2 x TBPRD ×  $T_{TBCLK}$
- B Duty modulation for EPWMxA is set by CMPA, and is active low (that is, the low time duty is proportional to CMPA).
- C Duty modulation for EPWMxB is set by CMPB and is active low (that is, the low time duty is proportional to CMPB).
- D Outputs EPWMxA and EPWMxB can drive independent power switches

Example 3-4 contains a code sample showing initialization and run time for the waveforms in Figure 3-25. Use the constant definitions in the device-specific header file.

## Example 3-4. Code Sample for Figure 3-25

// Initialization Time

#### Example 3-4. Code Sample for Figure 3-25 (continued)

```
EPwmlRegs.TBPRD = 600;
                                          // Period = 2'600 TBCLK counts
EPwmlRegs.CMPA.half.CMPA = 400;
                                          // Compare A = 400 TBCLK counts
EPwmlRegs.CMPB = 500;
                                          // Compare B = 500 TBCLK counts
EPwmlRegs.TBPHS = 0;
                                          // Set Phase register to zero
EPwmlRegs.TBCTR = 0;
                                          // clear TB counter
EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetric
xEPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE; // Phase loading disabled
xEPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwm1Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
EPwmlRegs.TBCTL.bit.HSPCLKDIV = TB_DIV1;
                                         // TBCLK = SYSCLKOUT
EPwmlRegs.TBCTL.bit.CLKDIV = TB_DIV1;
EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR = Zero
EPwm1Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR = Zero
EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
EPwmlRegs.AQCTLA.bit.CAD = AQ_CLEAR;
EPwmlRegs.AQCTLB.bit.CBU = AQ_SET;
EPwmlRegs.AQCTLB.bit.CBD = AQ_CLEAR;
//
// Run Time
EPwmlRegs.CMPA.half.CMPA = Duty1A;
                                         // adjust duty for output EPWM1A
EPwmlRegs.CMPB = DutylB;
                                         // adjust duty for output EPWM1B
```



# Figure 3-26. Up-Down-Count, Dual Edge Symmetric Waveform, With Independent Modulation on EPWMxA and EPWMxB — Complementary

- A PWM period =  $2 \times \text{TBPRD} \times \text{T}_{\text{TBCLK}}$
- B Duty modulation for EPWMxA is set by CMPA, and is active low, that is, low time duty proportional to CMPA
- C Duty modulation for EPWMxB is set by CMPB and is active high, that is., high time duty proportional to CMPB
- D Outputs EPWMx can drive upper/lower (complementary) power switches
- E Dead-band = CMPB CMPA (fully programmable edge placement by software). Note the dead-band module is also available if the more classical edge delay method is required.

Example 3-5 contains a code sample showing initialization and run time for the waveforms in Figure 3-26. Use the constant definitions in the device-specific header file.

#### Example 3-5. Code Sample for Figure 3-26

```
// Initialization Time
// = = = = = = = = = = = = = = = = =
                              _ _ _ _ _ _ _ _ _ _ _ _
                                             // Period = 2'600 TBCLK counts
EPwmlRegs.TBPRD = 600;
                                             // Compare A = 350 TBCLK counts
EPwmlRegs.CMPA.half.CMPA = 350;
EPwmlRegs.CMPB = 400;
                                             // Compare B = 400 TBCLK counts
EPwmlRegs.TBPHS = 0;
                                             // Set Phase register to zero
EPwmlRegs.TBCTR = 0;
                                             // clear TB counter
EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetric
EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE; // Phase loading disabled
EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwm1Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
EPwmlRegs.TBCTL.bit.HSPCLKDIV = TB_DIV1; // TBCLK = SYSCLKOUT
EPwmlRegs.TBCTL.bit.CLKDIV = TB_DIV1;
EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR = Zero
EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR = Zero
EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
EPwmlRegs.AQCTLA.bit.CAD = AQ_CLEAR;
EPwmlRegs.AQCTLB.bit.CBU = AQ_CLEAR;
EPwmlRegs.AQCTLB.bit.CBD = AQ_SET;
// Run Time
EPwmlRegs.CMPA.half.CMPA = Duty1A;
                                         // adjust duty for output EPWM1A
EPwmlRegs.CMPB = Duty1B;
                                          // adjust duty for output EPWM1B
```

# Figure 3-27. Up-Down-Count, Dual Edge Asymmetric Waveform, With Independent Modulation on EPWMxA—Active Low



- A PWM period = 2 × TBPRD × TBCLK
- B Rising edge and falling edge can be asymmetrically positioned within a PWM cycle. This allows for pulse placement techniques.
- C Duty modulation for EPWMxA is set by CMPA and CMPB.
- D Low time duty for EPWMxA is proportional to (CMPA + CMPB).
- E To change this example to active high, CMPA and CMPB actions need to be inverted (that is, Set ! Clear and Clear Set).
- F Duty modulation for EPWMxB is fixed at 50% (utilizes spare action resources for EPWMxB)

Example 3-6 contains a code sample showing initialization and run time for the waveforms in Figure 3-27. Use the constant definitions in the device-specific header file.

## Example 3-6. Code Sample for Figure 3-27

```
// Initialization Time
// = = = = = = = = = = = = =
                                            // Period = 2 ' 600 TBCLK counts
EPwmlRegs.TBPRD = 600;
                                            // Compare A = 250 TBCLK counts
EPwmlRegs.CMPA.half.CMPA = 250;
EPwmlRegs.CMPB = 450;
                                            // Compare B = 450 TBCLK counts
EPwmlRegs.TBPHS = 0;
                                            // Set Phase register to zero
EPwmlRegs.TBCTR = 0;
                                            // clear TB counter
EPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetric
EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE; // Phase loading disabled
EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwmlRegs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
EPwmlRegs.TBCTL.bit.HSPCLKDIV = TB_DIV1;
                                       // TBCLK = SYSCLKOUT
EPwmlRegs.TBCTL.bit.CLKDIV = TB_DIV1;
EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwmlReqs.CMPCTL.bit.SHDWBMODE = CC SHADOW;
EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR = Zero
EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR = Zero
EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
EPwmlRegs.AQCTLA.bit.CBD = AQ_CLEAR;
EPwmlRegs.AQCTLB.bit.ZRO = AQ_CLEAR;
EPwmlRegs.AQCTLB.bit.PRD = AQ_SET;
// Run Time
EPwmlRegs.CMPA.half.CMPA = EdgePosA;
                                           // adjust duty for output EPWM1A only
EPwmlRegs.CMPB = EdgePosB;
```



#### ePWM Submodules

## 3.2.5 Dead-Band Generator (DB) Submodule

Figure 3-28 illustrates the dead-band submodule within the ePWM module.



#### Figure 3-28. Dead\_Band Submodule

## 3.2.5.1 Purpose of the Dead-Band Submodule

The "Action-qualifier (AQ) Module" section discussed how it is possible to generate the required deadband by having full control over edge placement using both the CMPA and CMPB resources of the ePWM module. However, if the more classical edge delay-based dead-band with polarity control is required, then the dead-band submodule described here should be used.

The key functions of the dead-band module are:

- Generating appropriate signal pairs (EPWMxA and EPWMxB) with dead-band relationship from a single EPWMxA input
- Programming signal pairs for:
  - Active high (AH)
  - Active low (AL)
  - Active high complementary (AHC)
  - Active low complementary (ALC)
- Adding programmable delay to rising edges (RED)
- Adding programmable delay to falling edges (FED)
- Can be totally bypassed from the signal path (note dotted lines in diagram)

#### 3.2.5.2 Controlling and Monitoring the Dead-Band Submodule

The dead-band submodule operation is controlled and monitored via the following registers:

|                |                  | 5                                           |
|----------------|------------------|---------------------------------------------|
| Address offset | Shadowed         | Description                                 |
| 0x000F         | No               | Dead-Band Control Register                  |
| 0x0010         | No               | Dead-Band Rising Edge Delay Count Register  |
| 0x0011         | No               | Dead-Band Falling Edge Delay Count Register |
|                | 0x000F<br>0x0010 | 0x000F No<br>0x0010 No                      |

#### Table 3-13. Dead-Band Generator Submodule Registers

## 3.2.5.3 Operational Highlights for the Dead-Band Submodule

The following sections provide the operational highlights.

The dead-band submodule has two groups of independent selection options as shown in Figure 3-29.

#### Input Source Selection:

The input signals to the dead-band module are the EPWMxA and EPWMxB output signals from the action-qualifier. In this section they will be referred to as EPWMxA In and EPWMxB In. Using the DBCTL[IN\_MODE) control bits, the signal source for each delay, falling-edge or rising-edge, can be selected:

- EPWMxA In is the source for both falling-edge and rising-edge delay. This is the default mode.
- EPWMxA In is the source for falling-edge delay, EPWMxB In is the source for rising-edge delay.
- EPWMxA In is the source for rising edge delay, EPWMxB In is the source for falling-edge delay.
- EPWMxB In is the source for both falling-edge and rising-edge delay.

#### Half Cycle Clocking:

The dead-band submodule can be clocked using half cycle clocking to double the resolution (that is, counter clocked at 2x TBCLK)

#### • Output Mode Control:

The output mode is configured by way of the DBCTL[OUT\_MODE] bits. These bits determine if the falling-edge delay, rising-edge delay, neither, or both are applied to the input signals.

#### • Polarity Control:

The polarity control (DBCTL[POLSEL]) allows you to specify whether the rising-edge delayed signal and/or the falling-edge delayed signal is to be inverted before being sent out of the dead-band submodule.



## Figure 3-29. Configuration Options for the Dead-Band Submodule

EPWMxB in -

Although all combinations are supported, not all are typical usage modes. Table 3-14 documents some classical dead-band configurations. These modes assume that the DBCTL[IN\_MODE] is configured such that EPWMxA In is the source for both falling-edge and rising-edge delay. Enhanced, or non-traditional modes can be achieved by changing the input signal source. The modes shown in Table 3-14 fall into the following categories:

## Mode 1: Bypass both falling-edge delay (FED) and rising-edge delay (RED)

Allows you to fully disable the dead-band submodule from the PWM signal path.

Mode 2-5: Classical Dead-Band Polarity Settings:

These represent typical polarity configurations that should address all the active high/low modes required by available industry power switch gate drivers. The waveforms for these typical cases are shown in Figure 3-30. Note that to generate equivalent waveforms to Figure 3-30, configure the actionqualifier submodule to generate the signal as shown for EPWMxA.

#### • Mode 6: Bypass rising-edge-delay and Mode 7: Bypass falling-edge-delay

Finally the last two entries in Table 3-14 show combinations where either the falling-edge-delay (FED) or rising-edge-delay (RED) blocks are bypassed.

| Mode | Made Description                               | DBCTL[POLSEL] |        | DBCTL[OUT_MODE] |    |
|------|------------------------------------------------|---------------|--------|-----------------|----|
| wode | Mode Description                               | S3            | S2     | S1              | S0 |
| 1    | EPWMxA and EPWMxB Passed Through (No Delay)    | Х             | Х      | 0               | 0  |
| 2    | Active High Complementary (AHC)                | 1             | 0      | 1               | 1  |
| 3    | Active Low Complementary (ALC)                 | 0             | 1      | 1               | 1  |
| 4    | Active High (AH)                               | 0             | 0      | 1               | 1  |
| 5    | Active Low (AL)                                | 1             | 1      | 1               | 1  |
| 0    | EPWMxA Out = EPWMxA In (No Delay)              | 0 1           | 0 1    | 0               | 4  |
| 6    | EPWMxB Out = EPWMxA In with Falling Edge Delay | 0 or 1        | 0 or 1 | 0               | 1  |
| 7    | EPWMxA Out = EPWMxA In with Rising Edge Delay  | 0 1           | 0 1    | 4               | 0  |
| 1    | EPWMxB Out = EPWMxB In with No Delay           | 0 or 1        | 0 or 1 | 1               | 0  |

#### Table 3-14. Classical Dead-Band Operating Modes

Figure 3-30 shows waveforms for typical cases where 0% < duty < 100%.





The dead-band submodule supports independent values for rising-edge (RED) and falling-edge (FED) delays. The amount of delay is programmed using the DBRED and DBFED registers. These are 10-bit registers and their value represents the number of time-base clock, TBCLK, periods a signal edge is delayed by. For example, the formula to calculate falling-edge-delay and rising-edge-delay are:

 $FED = DBFED \times T_{TBCLK}$ 

 $\mathsf{RED} = \mathsf{DBRED} \times \mathsf{T}_{\mathsf{TBCLK}}$ 

Where  $T_{\text{TBCLK}}$  is the period of TBCLK, the prescaled version of SYSCLKOUT.

For convenience, delay values for various TBCLK options are shown in Table 3-15.

| Dead-Band Value | Dead-Band Delay in uS |                     |                     |  |  |
|-----------------|-----------------------|---------------------|---------------------|--|--|
| DBRED, DBFED    | TBCLK = SYSCLKOUT/1   | TBCLK = SYSCLKOUT/2 | TBCLK = SYSCLKOUT/4 |  |  |
| 1               | 0.02                  | 0.03                | 0.07                |  |  |
| 5               | 0.08                  | 0.17                | 0.33                |  |  |
| 10              | 0.17                  | 0.33                | 0.67                |  |  |
| 100             | 1.67                  | 3.33                | 6.67                |  |  |
| 200             | 3.33                  | 6.67                | 13.33               |  |  |
| 300             | 5.00                  | 10.00               | 20.00               |  |  |
| 400             | 6.67                  | 13.33               | 26.67               |  |  |
| 500             | 8.33                  | 16.67               | 33.33               |  |  |
| 600             | 10.00                 | 20.00               | 40.00               |  |  |
| 700             | 11.67                 | 23.33               | 46.67               |  |  |
| 800             | 13.33                 | 26.67               | 53.33               |  |  |
| 900             | 15.00                 | 30.00               | 60.00               |  |  |
| 1000            | 16.67                 | 33.33               | 66.67               |  |  |

When half-cycle clocking is enabled, the formula to calculate the falling-edge-delay and rising-edge-delay becomes:

 $FED = DBFED \times T_{TBCLK}/2$ 

 $RED = DBRED \times T_{TBCLK}/2$ 



## 3.2.6 PWM-Chopper (PC) Submodule

Figure 3-31 illustrates the PWM-chopper (PC) submodule within the ePWM module.



#### Figure 3-31. PWM-Chopper Submodule

The PWM-chopper submodule allows a high-frequency carrier signal to modulate the PWM waveform generated by the action-qualifier and dead-band submodules. This capability is important if you need pulse transformer-based gate drivers to control the power switching elements.

#### 3.2.6.1 Purpose of the PWM-Chopper Submodule

The key functions of the PWM-chopper submodule are:

- Programmable chopping (carrier) frequency
- Programmable pulse width of first pulse
- Programmable duty cycle of second and subsequent pulses

. .

• Can be fully bypassed if not required

#### 3.2.6.2 Controlling the PWM-Chopper Submodule

The PWM-chopper submodule operation is controlled via the registers in Table 3-16.

- -- -----

| Table 3-16.         PWM-Chopper Submodule Registers |                |          |                              |   |  |
|-----------------------------------------------------|----------------|----------|------------------------------|---|--|
| mnemonic                                            | Address offset | Shadowed | Description                  |   |  |
| PCCTL                                               | 0x001E         | No       | PWM-chopper Control Register | Ī |  |

#### 3.2.6.3 Operational Highlights for the PWM-Chopper Submodule

Figure 3-32 shows the operational details of the PWM-chopper submodule. The carrier clock is derived from SYSCLKOUT. Its frequency and duty cycle are controlled via the CHPFREQ and CHPDUTY bits in the PCCTL register. The one-shot block is a feature that provides a high energy first pulse to ensure hard and fast power switch turn on, while the subsequent pulses sustain pulses, ensuring the power switch remains on. The one-shot width is programmed via the OSHTWTH bits. The PWM-chopper submodule can be fully disabled (bypassed) via the CHPEN bit.





## Figure 3-32. PWM-Chopper Submodule Operational Details

## 3.2.6.4 Waveforms

Figure 3-33 shows simplified waveforms of the chopping action only; one-shot and duty-cycle control are not shown. Details of the one-shot and duty-cycle control are discussed in the following sections.







#### 3.2.6.4.1 One-Shot Pulse

The width of the first pulse can be programmed to any of 16 possible pulse width values. The width or period of the first pulse is given by:

 $T_{1stpulse} = T_{SYSCLKOUT} \times 8 \times OSHTWTH$ 

Where  $T_{SYSCLKOUT}$  is the period of the system clock (SYSCLKOUT) and OSHTWTH is the four control bits (value from 1 to 16)

Figure 3-34 shows the first and subsequent sustaining pulses and Table 7.3 gives the possible pulse width values for a SYSCLKOUT = 100 MHz.

#### Figure 3-34. PWM-Chopper Submodule Waveforms Showing the First Pulse and Subsequent Sustaining Pulses



#### Table 3-17. Possible Pulse Width Values for SYSCLKOUT = 100 MHz

| OSHTWTHz<br>(hex) | Pulse Width<br>(nS) |
|-------------------|---------------------|
| 0                 | 80                  |
| 1                 | 160                 |
| 2                 | 240                 |
| 3                 | 320                 |
| 4                 | 400                 |
| 5                 | 480                 |
| 6                 | 560                 |
| 7                 | 640                 |
| 8                 | 720                 |
| 9                 | 800                 |
| А                 | 880                 |
| В                 | 960                 |
| С                 | 1040                |
| D                 | 1120                |
| E                 | 1200                |
| F                 | 1280                |



ePWM Submodules

| OSHTWTHz<br>(hex) | Pulse Width<br>(nS) |
|-------------------|---------------------|
| 0                 | 100                 |
| 1                 | 200                 |
| 2                 | 300                 |
| 3                 | 400                 |
| 4                 | 500                 |
| 5                 | 600                 |
| 6                 | 700                 |
| 7                 | 800                 |
| 8                 | 900                 |
| 9                 | 1000                |
| А                 | 1100                |
| В                 | 1200                |
| С                 | 1300                |
| D                 | 1400                |
| E                 | 1500                |
| F                 | 1600                |

## 3.2.6.4.2 Duty Cycle Control

Pulse transformer-based gate drive designs need to comprehend the magnetic properties or characteristics of the transformer and associated circuitry. Saturation is one such consideration. To assist the gate drive designer, the duty cycles of the second and subsequent pulses have been made programmable. These sustaining pulses ensure the correct drive strength and polarity is maintained on the power switch gate during the on period, and hence a programmable duty cycle allows a design to be tuned or optimized via software control.

Figure 3-35 shows the duty cycle control that is possible by programming the CHPDUTY bits. One of seven possible duty ratios can be selected ranging from 12.5% to 87.5%.







#### ePWM Submodules

## 3.2.7 Trip-Zone (TZ) Submodule

Figure 3-36 shows how the trip-zone (TZ) submodule fits within the ePWM module.



Figure 3-36. Trip-Zone Submodule

Each ePWM module is connected to six TZn signals (TZ1 to TZ6). TZ1 to TZ3 are sourced from the GPIO mux. TZ4 is sourced from an inverted EQEP1ERR signal on those devices with an EQEP1 module. TZ5 is connected to the system clock fail logic, and TZ6 is sourced from the EMUSTOP output from the CPU. These signals indicate external fault or trip conditions, and the ePWM outputs can be programmed to respond accordingly when faults occur.

## 3.2.7.1 Purpose of the Trip-Zone Submodule

The key functions of the Trip-Zone submodule are:

- Trip inputs TZ1 to TZ6 can be flexibly mapped to any ePWM module.
- Upon a fault condition, outputs EPWMxA and EPWMxB can be forced to one of the following:
  - High
  - Low
  - High-impedance
  - No action taken
- Support for one-shot trip (OSHT) for major short circuits or over-current conditions.
- Support for cycle-by-cycle tripping (CBC) for current limiting operation.
- Support for digital compare tripping (DC) based on state of on-chip analog comparator module outputs and/or TZ1 to TZ3 signals.
- Each trip-zone input and digital compare (DC) submodule DCAEVT1/2 or DCBEVT1/2 force event can be allocated to either one-shot or cycle-by-cycle operation.
- Interrupt generation is possible on any trip-zone input.
- Software-forced tripping is also supported.
- The trip-zone submodule can be fully bypassed if it is not required.

## 3.2.7.2 Controlling and Monitoring the Trip-Zone Submodule

The trip-zone submodule operation is controlled and monitored through the following registers:

| Register Name | Address offset | Shadowed | Description <sup>(1)</sup>                               |
|---------------|----------------|----------|----------------------------------------------------------|
| TZSEL         | 0x0012         | No       | Trip-Zone Select Register                                |
| TZDCSEL       | 0x0013         | No       | Trip-zone Digital Compare Select Register <sup>(2)</sup> |
| TZCTL         | 0x0014         | No       | Trip-Zone Control Register                               |
| TZEINT        | 0x0015         | No       | Trip-Zone Enable Interrupt Register                      |
| TZFLG         | 0x0016         | No       | Trip-Zone Flag Register                                  |
| TZCLR         | 0x0017         | No       | Trip-Zone Clear Register                                 |
| TZFRC         | 0x0018         | No       | Trip-Zone Force Register                                 |

#### Table 3-18. Trip-Zone Submodule Registers

<sup>(1)</sup> All trip-zone registers are EALLOW protected and can be modified only after executing the EALLOW instruction. For more information, see the device-specific version of the System Control and Interrupts Reference Guide listed in Section 1.

<sup>(2)</sup> This register is discussed in more detail in Section 3.2.9 Digital Compare submodule.

## 3.2.7.3 Operational Highlights for the Trip-Zone Submodule

The following sections describe the operational highlights and configuration options for the trip-zone submodule.

The trip-zone signals TZ1 to TZ6 (also collectively referred to as TZn) are active low input signals. When one of these signals goes low, or when a DCAEVT1/2 or DCBEVT1/2 force happens based on the TZDCSEL register event selection, it indicates that a trip event has occurred. Each ePWM module can be individually configured to ignore or use each of the trip-zone signals or DC events. Which trip-zone signals or DC events are used by a particular ePWM module is determined by the TZSEL register for that specific ePWM module. The trip-zone signals may or may not be synchronized to the system clock (SYSCLKOUT) and digitally filtered within the GPIO MUX block. A minimum of 3\*TBCLK low pulse width on TZn inputs is sufficient to trigger a fault condition on the ePWM module. If the pulse width is less than this, the trip condition may not be latched by CBC or OST latches. The asynchronous trip makes sure that if clocks are missing for any reason, the outputs can still be tripped by a valid event present on TZn inputs. The GPIOs or peripherals must be appropriately configured. For more information, see the device-specific version of the *System Control and Interrupts Reference Guide* listed in .

Each TZn input can be individually configured to provide either a cycle-by-cycle or one-shot trip event for an ePWM module. DCAEVT1 and DCBEVT1 events can be configured to directly trip an ePWM module or provide a one-shot trip event to the module. Likewise, DCAVET2 and DCBEVT2 events can also be configured to directly trip an ePWM module or provide a cycle-by-cycle trip event to the module. This configuration is determined by the TZSEL[DCAEVT1/2], TZSEL[DCBEVT1/2], TZSEL[CBCn], and TZSEL[OSHTn] control bits (where n corresponds to the trip input) respectively.

## • Cycle-by-Cycle (CBC):

When a cycle-by-cycle trip event occurs, the action specified in the TZCTL[TZA] and TZCTL[TZB] bits is carried out immediately on the EPWMxA and/or EPWMxB output. Table 3-19 lists the possible actions. In addition, the cycle-by-cycle trip event flag (TZFLG[CBC]) is set and a EPWMx\_TZINT interrupt is generated if it is enabled in the TZEINT register and PIE peripheral.

If the CBC interrupt is enabled via the TZEINT register, and DCAEVT2 or DCBEVT2 are selected as CBC trip sources via the TZSEL register, it is not necessary to also enable the DCAEVT2 or DCBEVT2 interrupts in the TZEINT register, as the DC events trigger interrupts through the CBC mechanism.

The specified condition on the inputs is automatically cleared when the ePWM time-base counter reaches zero (TBCTR = 0x0000) if the trip event is no longer present. Therefore, in this mode, the trip event is cleared or reset every PWM cycle. The TZFLG[CBC] flag bit will remain set until it is manually cleared by writing to the TZCLR[CBC] bit. If the cycle-by-cycle trip event is still present when the TZFLG[CBC] bit is cleared, then it will again be immediately set.

#### • One-Shot (OSHT):

When a one-shot trip event occurs, the action specified in the TZCTL[TZA] and TZCTL[TZB] bits is carried out immediately on the EPWMxA and/or EPWMxB output. Table 3-19 lists the possible actions.



In addition, the one-shot trip event flag (TZFLG[OST]) is set and a EPWMx\_TZINT interrupt is generated if it is enabled in the TZEINT register and PIE peripheral. The one-shot trip condition must be cleared manually by writing to the TZCLR[OST] bit.

If the one-shot interrupt is enabled via the TZEINT register, and DCAEVT1 or DCBEVT1 are selected as OSHT trip sources via the TZSEL register, it is not necessary to also enable the DCAEVT1 or DCBEVT1 interrupts in the TZEINT register, as the DC events trigger interrupts through the OSHT mechanism.

## • Digital Compare Events (DCAEVT1/2 and DCBEVT1/2):

A digital compare DCAEVT1/2 or DCBEVT1/2 event is generated based on a combination of the DCAH/DCAL and DCBH/DCBL signals as selected by the TZDCSEL register. The signals which source the DCAH/DCAL and DCBH/DCBL signals are selected via the DCTRIPSEL register and can be either trip zone input pins or CTRIP Output Subsystem CTRIPxx signals. For more information on the digital compare submodule signals, see Section 3.2.9.

When a digital compare event occurs, the action specified in the TZCTL[DCAEVT1/2] and TZCTL[DCBEVT1/2] bits is carried out immediately on the EPWMxA and/or EPWMxB output. Table 3-19 lists the possible actions. In addition, the relevant DC trip event flag (TZFLG[DCAEVT1/2] / TZFLG[DCBEVT1/2]) is set and a EPWMx\_TZINT interrupt is generated if it is enabled in the TZEINT register and PIE peripheral.

The specified condition on the pins is automatically cleared when the DC trip event is no longer present. The TZFLG[DCAEVT1/2] or TZFLG[DCBEVT1/2] flag bit will remain set until it is manually cleared by writing to the TZCLR[DCAEVT1/2] or TZCLR[DCBEVT1/2] bit. If the DC trip event is still present when the TZFLG[DCAEVT1/2] or TZFLG[DCBEVT1/2] flag is cleared, then it will again be immediately set.

The action taken when a trip event occurs can be configured individually for each of the ePWM output pins by way of the TZCTL register bit fields. One of four possible actions, shown in Table 3-19, can be taken on a trip event.



Table 3-19. Possible Actions On a Trip Event

| TZCTL Register bit-<br>field Settings | EPWMxA<br>and/or<br>EPWMxB | Comment                                         |
|---------------------------------------|----------------------------|-------------------------------------------------|
| 0,0                                   | High-Impedance             | Tripped                                         |
| 0,1                                   | Force to High State        | Tripped                                         |
| 1,0                                   | Force to Low State         | Tripped                                         |
| 1,1                                   | No Change                  | Do Nothing.<br>No change is made to the output. |

## Example 3-7. Trip-Zone Configurations

## Scenario A:

A one-shot trip event on TZ1 pulls both EPWM1A, EPWM1B low and also forces EPWM2A and EPWM2B high.

- Configure the ePWM1 registers as follows:
  - TZSEL[OSHT1] = 1: enables TZ1 as a one-shot event source for ePWM1
  - TZCTL[TZA] = 2: EPWM1A will be forced low on a trip event.
  - TZCTL[TZB] = 2: EPWM1B will be forced low on a trip event.
- Configure the ePWM2 registers as follows:
  - TZSEL[OSHT1] = 1: enables  $\overline{TZ1}$  as a one-shot event source for ePWM2
  - TZCTL[TZA] = 1: EPWM2A will be forced high on a trip event.
  - TZCTL[TZB] = 1: EPWM2B will be forced high on a trip event.

## Scenario B:

A cycle-by-cycle event on  $\overline{TZ5}$  pulls both EPWM1A, EPWM1B low.

A one-shot event on  $\overline{TZ1}$  or  $\overline{TZ6}$  puts EPWM2A into a high impedance state.

- Configure the ePWM1 registers as follows:
  - TZSEL[CBC5] = 1: enables TZ5 as a one-shot event source for ePWM1
  - TZCTL[TZA] = 2: EPWM1A will be forced low on a trip event.
  - TZCTL[TZB] = 2: EPWM1B will be forced low on a trip event.
- Configure the ePWM2 registers as follows:
  - TZSEL[OSHT1] = 1: enables  $\overline{TZ1}$  as a one-shot event source for ePWM2
  - TZSEL[OSHT6] = 1: enables  $\overline{TZ6}$  as a one-shot event source for ePWM2
  - TZCTL[TZA] = 0: EPWM2A will be put into a high-impedance state on a trip event.
  - TZCTL[TZB] = 3: EPWM2B will ignore the trip event.

## 3.2.7.4 Generating Trip Event Interrupts

Figure 3-37 and Figure 3-38 illustrate the trip-zone submodule control and interrupt logic, respectively. DCAEVT1/2 and DCBEVT1/2 signals are described in further detail in Section 3.2.9.





TRUMENTS

Texas



## 3.2.8 Event-Trigger (ET) Submodule

The key functions of the event-trigger submodule are:

- Receives event inputs generated by the time-base, counter-compare and digital-compare submodules
- Uses the time-base direction information for up/down event qualification
- Uses prescaling logic to issue interrupt requests and ADC start of conversion at:
  - Every event
  - Every second event
  - Every third event
- Provides full visibility of event generation via event counters and flags
- Allows software forcing of Interrupts and ADC start of conversion

The event-trigger submodule manages the events generated by the time-base submodule, the countercompare submodule, and the digital-compare submodule to generate an interrupt to the CPU and/or a start of conversion pulse to the ADC when a selected event occurs. Figure 3-39 illustrates where the event-trigger submodule fits within the ePWM system.





Figure 3-39. Event-Trigger Submodule

## 3.2.8.1 Operational Overview of the Event-Trigger Submodule

The following sections describe the event-trigger submodule's operational highlights.

Each ePWM module has one interrupt request line connected to the PIE and two start of conversion signals connected to the ADC module. As shown in Figure 3-40, ADC start of conversion for all ePWM modules are connected to individual ADC trigger inputs to the ADC, and hence multiple modules can initiate an ADC start of conversion via the ADC trigger inputs.





The event-trigger submodule monitors various event conditions (the left side inputs to event-trigger submodule shown in Figure 3-41) and can be configured to prescale these events before issuing an Interrupt request or an ADC start of conversion. The event-trigger prescaling logic can issue Interrupt requests and ADC start of conversion at:

- Every event
- Every second event

• Every third event



## Figure 3-41. Event-Trigger Submodule Showing Event Inputs and Prescaled Outputs

The key registers used to configure the event-trigger submodule are shown in Table 3-20:

|               |                |          | _                                |  |
|---------------|----------------|----------|----------------------------------|--|
| Register Name | Address offset | Shadowed | Description                      |  |
| ETSEL         | 0x0019         | No       | Event-trigger Selection Register |  |
| ETPS          | 0x001A         | No       | Event-trigger Prescale Register  |  |
| ETFLG         | 0x001B         | No       | Event-trigger Flag Register      |  |
| ETCLR         | 0x001C         | No       | Event-trigger Clear Register     |  |
| ETFRC         | 0x001D         | No       | Event-trigger Force Register     |  |
|               |                |          |                                  |  |

#### Table 3-20. Event-Trigger Submodule Registers

- ETSEL—This selects which of the possible events will trigger an interrupt or start an ADC conversion
- ETPS—This programs the event prescaling options mentioned above.
- ETFLG—These are flag bits indicating status of the selected and prescaled events.
- ETCLR—These bits allow you to clear the flag bits in the ETFLG register via software.
- ETFRC—These bits allow software forcing of an event. Useful for debugging or s/w intervention.

A more detailed look at how the various register bits interact with the Interrupt and ADC start of conversion logic are shown in Figure 3-42, Figure 3-43, and Figure 3-44.

Figure 3-42 shows the event-trigger's interrupt generation logic. The interrupt-period (ETPS[INTPRD]) bits specify the number of events required to cause an interrupt pulse to be generated. The choices available are:

- Do not generate an interrupt.
- Generate an interrupt on every event
- · Generate an interrupt on every second event
- Generate an interrupt on every third event

Which event can cause an interrupt is configured by the interrupt selection (ETSEL[INTSEL]) bits. The event can be one of the following:

- Time-base counter equal to zero (TBCTR = 0x0000).
- Time-base counter equal to period (TBCTR = TBPRD).
- Time-base counter equal to zero or period (TBCTR = 0x0000 || TBCTR = TBPRD)
- Time-base counter equal to the compare A register (CMPA) when the timer is incrementing.



- Time-base counter equal to the compare A register (CMPA) when the timer is decrementing.
- Time-base counter equal to the compare B register (CMPB) when the timer is incrementing.
- Time-base counter equal to the compare B register (CMPB) when the timer is decrementing.

The number of events that have occurred can be read from the interrupt event counter (ETPS[INTCNT]) register bits. That is, when the specified event occurs, the ETPS[INTCNT] bits are incremented until they reach the value specified by ETPS[INTPRD]. When ETPS[INTCNT] = ETPS[INTPRD], the counter stops counting and its output is set. The counter is only cleared when an interrupt is sent to the PIE.

When ETPS[INTCNT] reaches ETPS[INTPRD] the following behaviors will occur:

- If interrupts are enabled, ETSEL[INTEN] = 1 and the interrupt flag is clear, ETFLG[INT] = 0, then an interrupt pulse is generated and the interrupt flag is set, ETFLG[INT] = 1, and the event counter is cleared ETPS[INTCNT] = 0. The counter will begin counting events again.
- If interrupts are disabled, ETSEL[INTEN] = 0, or the interrupt flag is set, ETFLG[INT] = 1, the counter stops counting events when it reaches the period value ETPS[INTCNT] = ETPS[INTPRD].
- If interrupts are enabled, but the interrupt flag is already set, then the counter will hold its output high until the ENTFLG[INT] flag is cleared. This allows for one interrupt to be pending while one is serviced.

When writing INTPRD values the following occur:

- Writing to the INTPRD bits will automatically clear the counter INTCNT = 0 and the counter output will be reset (so no interrupts are generated).
- Writing an INTPRD value that is GREATER or equal to the current counter value will reset the INTCNT = 0.
- - Writing an INTPRD value that is equal to the current counter value will trigger an interrupt if it is enabled and the status flag is cleared (and INTCNT will also be cleared to 0)
- Writing an INTPRD value that is LESS than the current counter value will result in undefined behavior (that is, INTCNT stops counting because INTPRD is below INTCNT, and interrupt will never fire).
- Writing a 1 to the ETFRC[INT] bit will increment the event counter INTCNT. The counter will behave as described above when INTCNT = INTPRD.
- When INTPRD = 0, the counter is disabled and hence no events will be detected and the ETFRC[INT] bit is also ignored.

The above definition means that you can generate an interrupt on every event, on every second event, or on every third event. An interrupt cannot be generated on every fourth or more events.



## Figure 3-42. Event-Trigger Interrupt Generator



Figure 3-43 shows the operation of the event-trigger's start-of-conversion-A (SOCA) pulse generator. The ETPS[SOCACNT] counter and ETPS[SOCAPRD] period values behave similarly to the interrupt generator except that the pulses are continuously generated. That is, the pulse flag ETFLG[SOCA] is latched when a pulse is generated, but it does not stop further pulse generation. The enable/disable bit ETSEL[SOCAEN] stops pulse generation, but input events can still be counted until the period value is reached as with the interrupt generation logic. The event that will trigger an SOCA and SOCB pulse can be configured separately in the ETSEL[SOCASEL] and ETSEL[SOCBSEL] bits. The possible events are the same events that can be specified for the interrupt generation logic with the addition of the DCAEVT1.soc and DCBEVT1.soc event signals from the digital compare (DC) submodule.



#### Figure 3-43. Event-Trigger SOCA Pulse Generator

A The DCAEVT1.soc signals are signals generated by the Digital compare (DC) submodule described later in Section 3.2.9

Figure 3-44 shows the operation of the event-trigger's start-of-conversion-B (SOCB) pulse generator. The event-trigger's SOCB pulse generator operates the same way as the SOCA.

## Figure 3-44. Event-Trigger SOCB Pulse Generator



A The DCBEVT1.soc signals are signals generated by the Digital compare (DC) submodule described later in Section 3.2.9

## 3.2.9 Digital Compare (DC) Submodule

Figure 3-45 illustrates where the digital compare (DC) submodule signals interface to other submodules in the ePWM system.



#### Figure 3-45. Digital-Compare Submodule High-Level Block Diagram

The digital compare (DC) submodule compares signals external to the ePWM module (for instance, CTRIPxx signals from the CTRIP Output Subsystem) to directly generate PWM events/actions which then feed to the event-trigger, trip-zone, and time-base submodules. Additionally, blanking window functionality is supported to filter noise or unwanted pulses from the DC event signals.

## 3.2.9.1 Purpose of the Digital Compare Submodule

The key functions of the digital compare submodule are:

- The CTRIP Output Subsystem module outputs and TZ1, TZ2, and TZ3 inputs generate Digital Compare A High/Low (DCAH, DCAL) and Digital Compare B High/Low (DCBH, DCBL) signals.
- DCAH/L and DCBH/L signals trigger events which can then either be filtered or fed directly to the tripzone, event-trigger, and time-base submodules to:
  - generate a trip zone interrupt
  - generate an ADC start of conversion
  - force an event
  - generate a synchronization event for synchronizing the ePWM module TBCTR.
- Event filtering (blanking window logic) can optionally blank the input signal to remove noise.

#### 3.2.9.2 Controlling and Monitoring the Digital Compare Submodule

The digital compare submodule operation is controlled and monitored through the following registers:

Table 3-21. Digital Compare Submodule Registers

| Register Name                         | Address offset | Shadowed | Description                                    |
|---------------------------------------|----------------|----------|------------------------------------------------|
| TZDCSEL <sup>(1)</sup> <sup>(2)</sup> | 0x13           | No       | Trip Zone Digital Compare Select Register      |
| DCTRIPSEL <sup>(1)</sup>              | 0x30           | No       | Digital Compare Trip Select Register           |
| DCACTL <sup>(1)</sup>                 | 0x31           | No       | Digital Compare A Control Register             |
| DCBCTL <sup>(1)</sup>                 | 0x32           | No       | Digital Compare B Control Register             |
| DCFCTL <sup>(1)</sup>                 | 0x33           | No       | Digital Compare Filter Control Register        |
| DCCAPCTL <sup>(1)</sup>               | 0x34           | No       | Digital Compare Capture Control Register       |
| DCFOFFSET                             | 0x35           | Writes   | Digital Compare Filter Offset Register         |
| DCFOFFSETCNT                          | 0x36           | No       | Digital Compare Filter Offset Counter Register |
| DCFWINDOW                             | 0x37           | No       | Digital Compare Filter Window Register         |

<sup>(1)</sup> These registers are EALLOW protected and can be modified only after executing the EALLOW instruction. For more information, see the device-specific version of the System Control and Interrupts Reference Guide.

<sup>(2)</sup> The TZDCSEL register is part of the trip-zone submodule but is mentioned again here because of its functional significance to the digital compare submodule.

| Register Name | Address offset | Shadowed | Description                                    |
|---------------|----------------|----------|------------------------------------------------|
| DCFWINDOWCNT  | 0x38           | No       | Digital Compare Filter Window Counter Register |
| DCCAP         | 0x39           | Yes      | Digital Compare Counter Capture Register       |

| Table 3-21. | Digital Compare | • Submodule | Registers | (continued) |
|-------------|-----------------|-------------|-----------|-------------|
|             |                 |             |           |             |

## 3.2.9.3 Operation Highlights of the Digital Compare Submodule

The following sections describe the operational highlights and configuration options for the digital compare submodule.

## 3.2.9.3.1 Digital Compare Events

As illustrated in Figure 3-45 earlier in this section, trip zone inputs (TZ1, TZ2, and TZ3) and CTRIPxx signals from the CTRIP Output Subsystem module can be selected via the DCTRIPSEL bits to generate the Digital Compare A High and Low (DCAH/L) and Digital Compare B High and Low (DCBH/L) signals. Then, the configuration of the TZDCSEL register qualifies the actions on the selected DCAH/L and DCBH/L signals, which generate the DCAEVT1/2 and DCBEVT1/2 events (Event Qualification A and B).

**NOTE:** The TZn signals, when used as a DCEVT tripping functions, are treated as a normal input signal and can be defined to be active high or active low inputs. EPWM outputs are asynchronously tripped when either the TZn, DCAEVTx.force, or DCBEVTx.force signals are active. For the condition to remain latched, a minimum of 3\*TBCLK sync pulse width is required. If pulse width is < 3\*TBCLK sync pulse width, the trip condition may or may not get latched by CBC or OST latches.

The DCAEVT1/2 and DCBEVT1/2 events can then be filtered to provide a filtered version of the event signals (DCEVTFILT) or the filtering can be bypassed. Filtering is discussed further in section 2.9.3.2. Either the DCAEVT1/2 and DCBEVT1/2 event signals or the filtered DCEVTFILT event signals can generate a force to the trip zone module, a TZ interrupt, an ADC SOC, or a PWM sync signal.

## force signal:

DCAEVT1/2.force signals force trip zone conditions which either directly influence the output on the EPWMxA pin (via TZCTL[DCAEVT1 or DCAEVT2] configurations) or, if the DCAEVT1/2 signals are selected as one-shot or cycle-by-cycle trip sources (via the TZSEL register), the DCAEVT1/2.force signals can effect the trip action via the TZCTL[TZA] configuration. The DCBEVT1/2.force signals behaves similarly, but affect the EPWMxB output pin instead of the EPWMxA output pin.

The priority of conflicting actions on the TZCTL register is as follows (highest priority overrides lower priority):

Output EPWMxA: TZA (highest) -> DCAEVT1 -> DCAEVT2 (lowest) Output EPWMxB: TZB (highest) -> DCBEVT1 -> DCBEVT2 (lowest)

## • interrupt signal:

DCAEVT1/2.interrupt signals generate trip zone interrupts to the PIE. To enable the interrupt, the user must set the DCAEVT1, DCAEVT2, DCBEVT1, or DCBEVT2 bits in the TZEINT register. Once one of these events occurs, an EPWMxTZINT interrupt is triggered, and the corresponding bit in the TZCLR register must be set in order to clear the interrupt.

#### • soc signal:

The DCAEVT1.soc signal interfaces with the event-trigger submodule and can be selected as an event which generates an ADC start-of-conversion-A (SOCA) pulse via the ETSEL[SOCASEL] bit. Likewise, the DCBEVT1.soc signal can be selected as an event which generates an ADC start-of-conversion-B (SOCB) pulse via the ETSEL[SOCBSEL] bit.

#### • sync signal:

The DCAEVT1.sync and DCBEVT1.sync events are ORed with the EPWMxSYNCI input signal and the TBCTL[SWFSYNC] signal to generate a synchronization pulse to the time-base counter.



ePWM Submodules

The diagrams below show how the DCAEVT1, DCAEVT2 or DCEVTFLT signals are processed to generate the digital compare A event force, interrupt, soc and sync signals.







ePWM Submodules

www.ti.com

The diagrams below show how the DCBEVT1, DCBEVT2 or DCEVTFLT signals are processed to generate the digital compare B event force, interrupt, soc and sync signals.



#### 3.2.9.3.2 Event Filtering

The DCAEVT1/2 and DCBEVT1/2 events can be filtered via event filtering logic to remove noise by optionally blanking events for a certain period of time. This is useful for cases where the analog comparator outputs may be selected to trigger DCAEVT1/2 and DCBEVT1/2 events, and the blanking logic is used to filter out potential noise on the signal prior to tripping the PWM outputs or generating an interrupt or ADC start-of-conversion. The event filtering can also capture the TBCTR value of the trip event. The diagram below shows the details of the event filtering logic.





If the blanking logic is enabled, one of the digital compare events – DCAEVT1, DCAEVT2, DCBEVT1, DCBEVT2 – is selected for filtering. The blanking window, which filters out all event occurrences on the signal while it is active, will be aligned to either a CTR = PRD pulse or a CTR = 0 pulse (configured by the DCFCTL[PULSESEL] bits). An offset value in TBCLK counts is programmed into the DCFOFFSET register, which determines at what point after the CTR = PRD or CTR = 0 pulse the blanking window starts. The duration of the blanking window, in number of TBCLK counts after the offset counter expires, is written to the DCFWINDOW register by the application. During the blanking window, all events are ignored. Before and after the blanking window ends, events can generate soc, sync, interrupt, and force signals as before.

The diagram below illustrates several timing conditions for the offset and blanking window within an ePWM period. Notice that if the blanking window crosses the CTR = 0 or CTR = PRD boundary, the next window still starts at the same offset value after the CTR = 0 or CTR = PRD pulse.



ePWM Submodules





## 3.3 Applications to Power Topologies

An ePWM module has all the local resources necessary to operate completely as a standalone module or to operate in synchronization with other identical ePWM modules.

## 3.3.1 Overview of Multiple Modules

Previously in this user's guide, all discussions have described the operation of a single module. To facilitate the understanding of multiple modules working together in a system, the ePWM module described in reference is represented by the more simplified block diagram shown in Figure 3-52. This simplified ePWM block shows only the key resources needed to explain how a multiswitch power topology is controlled with multiple ePWM modules working together.



Figure 3-52. Simplified ePWM Module

## 3.3.2 Key Configuration Capabilities

The key configuration choices available to each module are as follows:

- Options for SyncIn
  - Load own counter with phase register on an incoming sync strobe—enable (EN) switch closed
  - Do nothing or ignore incoming sync strobe—enable switch open
  - Sync flow-through SyncOut connected to SyncIn
  - Master mode, provides a sync at PWM boundaries—SyncOut connected to CTR = PRD
  - Master mode, provides a sync at any programmable point in time—SyncOut connected to CTR = CMPB
  - Module is in standalone mode and provides No sync to other modules—SyncOut connected to X (disabled)
- Options for SyncOut
  - Sync flow-through SyncOut connected to SyncIn
  - Master mode, provides a sync at PWM boundaries—SyncOut connected to CTR = PRD
  - Master mode, provides a sync at any programmable point in time—SyncOut connected to CTR = CMPB
  - Module is in standalone mode and provides No sync to other modules—SyncOut connected to X (disabled)

For each choice of SyncOut, a module may also choose to load its own counter with a new phase value on a SyncIn strobe input or choose to ignore it; that is, via the enable switch. Although various combinations are possible, the two most common—master module and slave module modes—are shown in Figure 3-53.



#### Applications to Power Topologies



## Figure 3-53. EPWM1 Configured as a Typical Master, EPWM2 Configured as a Slave

## 3.3.3 Controlling Multiple Buck Converters With Independent Frequencies

One of the simplest power converter topologies is the buck. A single ePWM module configured as a master can control two buck stages with the same PWM frequency. If independent frequency control is required for each buck converter, then one ePWM module must be allocated for each converter stage. Figure 3-54 shows four buck stages, each running at independent frequencies. In this case, all four ePWM modules are configured as Masters and no synchronization is used. Figure 3-55 shows the waveforms generated by the setup shown in Figure 3-54; note that only three waveforms are shown, although there are four stages.





Figure 3-54. Control of Four Buck Stages. Here F<sub>PWM1</sub>≠ F<sub>PWM2</sub>≠ F<sub>PWM3</sub>≠ F<sub>PWM4</sub>

NOTE:  $\Theta = X$  indicates value in phase register is a "don't care"



## Figure 3-55. Buck Waveforms for Figure 3-54 (Note: Only three bucks shown here)



## Example 3-8. Configuration for Example in Figure 3-55

Texas

www.ti.com

RUMENTS

```
// (Note: code for only 3 modules shown)
// Initialization Time
// EPWM Module 1 config
  EPwmlReqs.TBPRD = 1200;
                                                // Period = 1201 TBCLK counts
  EPwmlRegs.TBPHS.half.TBPHS = 0;
                                               // Set Phase register to zero
  EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
                                               // Asymmetrical mode
  EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE;
                                               // Phase loading disabled
  EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
  EPwmlRegs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
  EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
  EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
  EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
                                              // load on CTR=Zero
  EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR=Zero
  EPwmlRegs.AQCTLA.bit.PRD = AQ_CLEAR;
  EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
// EPWM Module 2 config
  EPwm2Regs.TBPRD = 1400;
                                               // Period = 1401 TBCLK counts
  EPwm2Regs.TBPHS.half.TBPHS = 0;
                                               // Set Phase register to zero
  EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
                                               // Asymmetrical mode
  EPwm2Regs.TBCTL.bit.PHSEN = TB_DISABLE;
                                               // Phase loading disabled
  EPwm2Regs.TBCTL.bit.PRDLD = TB_SHADOW;
  EPwm2Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
  EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
  EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
  EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
                                               // load on CTR=Zero
  EPwm2Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;
                                               // load on CTR=Zero
  EPwm2Regs.AQCTLA.bit.PRD = AQ_CLEAR;
  EPwm2Regs.AQCTLA.bit.CAU = AQ_SET;
// EPWM Module 3 config
  EPwm3Regs.TBPRD = 800;
                                                 // Period = 801 TBCLK counts
  EPwm3Regs.TBPHS.half.TBPHS = 0;
                                                 // Set Phase register to zero
  EPwm3Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
  EPwm3Regs.TBCTL.bit.PHSEN = TB_DISABLE;
                                                // Phase loading disabled
  EPwm3Regs.TBCTL.bit.PRDLD = TB_SHADOW;
  EPwm3Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;
  EPwm3Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
  EPwm3Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
  EPwm3Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
                                                // load on CTR=Zero
  EPwm3Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;
                                                // load on CTR=Zero
  EPwm3Regs.AQCTLA.bit.PRD = AQ_CLEAR;
  EPwm3Regs.AQCTLA.bit.CAU = AQ_SET;
11
// Run Time (Note: Example execution of one run-time instant)
EPwmlRegs.CMPA.half.CMPA = 700;
                                               // adjust duty for output EPWM1A
  EPwm2Regs.CMPA.half.CMPA = 700;
                                               // adjust duty for output EPWM2A
  EPwm3Regs.CMPA.half.CMPA = 500;
                                               // adjust duty for output EPWM3A
```



#### Applications to Power Topologies

www.ti.com

## 3.3.4 Controlling Multiple Buck Converters With Same Frequencies

If synchronization is a requirement, ePWM module 2 can be configured as a slave and can operate at integer multiple (N) frequencies of module 1. The sync signal from master to slave ensures these modules remain locked. Figure 3-56 shows such a configuration; Figure 3-57 shows the waveforms generated by the configuration.







# Example 3-9. Code Snippet for Configuration in Figure 3-56

```
// EPWM Module 1 config
    EPwmlRegs.TBPRD = 600;
                                                 // Period = 1200 TBCLK counts
    EPwmlRegs.TBPHS.half.TBPHS = 0;
                                                 // Set Phase register to zero
    EPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetrical mode
    EPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE; // Master module
    EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
    EPwmlRegs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO;
                                                 // Sync down-stream module
    EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
    EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
    EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR=Zero
    EPwm1Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR=Zero
    EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
                                                 // set actions for EPWM1A
    EPwmlRegs.AQCTLA.bit.CAD = AQ_CLEAR;
    EPwmlRegs.AQCTLB.bit.CBU = AQ_SET;
                                                 // set actions for EPWM1B
    EPwmlRegs.AQCTLB.bit.CBD = AQ_CLEAR;
// EPWM Module 2 config
    EPwm2Regs.TBPRD = 600;
                                                 // Period = 1200 TBCLK counts
    EPwm2Regs.TBPHS.half.TBPHS = 0;
                                                 // Set Phase register to zero
    EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetrical mode
    EPwm2Regs.TBCTL.bit.PHSEN = TB_ENABLE;
                                                 // Slave module
    EPwm2Regs.TBCTL.bit.PRDLD = TB_SHADOW;
    EPwm2Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN;
                                                 // sync flow-through
    EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
    EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
    EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR=Zero
    EPwm2Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR=Zero
    EPwm2Regs.AQCTLA.bit.CAU = AQ_SET;
                                                 // set actions for EPWM2A
    EPwm2Regs.AQCTLA.bit.CAD = AQ_CLEAR;
    EPwm2Regs.AQCTLB.bit.CBU = AQ_SET;
                                                 // set actions for EPWM2B
    EPwm2Regs.AQCTLB.bit.CBD = AQ_CLEAR;
11
// Run Time (Note: Example execution of one run-time instance)
EPwmlReqs.CMPA.half.CMPA = 400;
                                                // adjust duty for output EPWM1A
   EPwmlRegs.CMPB = 200;
                                                // adjust duty for output EPWM1B
   EPwm2Regs.CMPA.half.CMPA = 500;
                                                // adjust duty for output EPWM2A
   EPwm2Regs.CMPB = 300;
                                                // adjust duty for output EPWM2B
```



# 3.3.5 Controlling Multiple Half H-Bridge (HHB) Converters

Topologies that require control of multiple switching elements can also be addressed with these same ePWM modules. It is possible to control a Half-H bridge stage with a single ePWM module. This control can be extended to multiple stages. Figure 3-58 shows control of two synchronized Half-H bridge stages where stage 2 can operate at integer multiple (N) frequencies of stage 1. Figure 3-59 shows the waveforms generated by the configuration shown in Figure 3-58.

Module 2 (slave) is configured for Sync flow-through; if required, this configuration allows for a third Half-H bridge to be controlled by PWM module 3 and also, most importantly, to remain in synchronization with master module 1.









328



# Example 3-10. Code Snippet for Configuration in Figure 3-58

```
// Config
// Initialization Time
// EPWM Module 1 config
    EPwmlRegs.TBPRD = 600;
                                            // Period = 1200 TBCLK counts
    EPwmlRegs.TBPHS.half.TBPHS = 0;
                                            // Set Phase register to zero
    EPwmlReqs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetrical mode
    EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE; // Master module
    EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
    EPwmlReqs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO; // Sync down-stream module
    EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
    EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
    EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR=Zero
    EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR=Zero
    EPwmlRegs.AQCTLA.bit.ZRO = AQ_SET;
                                            // set actions for EPWM1A
    EPwmlRegs.AQCTLA.bit.CAU = AQ_CLEAR;
    EPwmlRegs.AQCTLB.bit.ZRO = AQ_CLEAR;
                                    // set actions for EPWM1B
    EPwmlRegs.AQCTLB.bit.CAD = AQ_SET;
// EPWM Module 2 config
                                            // Period = 1200 TBCLK counts
    EPwm2Regs.TBPRD = 600;
    EPwm2Regs.TBPHS.half.TBPHS = 0;
                                            // Set Phase register to zero
    EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetrical mode
    EPwm2Regs.TBCTL.bit.PHSEN = TB_ENABLE; // Slave module
    EPwm2Reqs.TBCTL.bit.PRDLD = TB SHADOW;
    EPwm2Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN;
                                           // sync flow-through
    EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
    EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
    EPwm2Reqs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR=Zero
    EPwm2Reqs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR=Zero
    EPwm2Regs.AQCTLA.bit.ZRO = AQ_SET;
                                           // set actions for EPWM1A
    EPwm2Regs.AQCTLA.bit.CAU = AQ_CLEAR;
    EPwm2Regs.AQCTLB.bit.ZRO = AQ_CLEAR;
                                            // set actions for EPWM1B
    EPwm2Regs.AQCTLB.bit.CAD = AQ_SET;
EPwmlRegs.CMPA.half.CMPA = 400;
                                            // adjust duty for output EPWM1A & EPWM1B
    EPwmlRegs.CMPB = 200;
                                            // adjust point-in-time for ADCSOC trigger
    EPwm2Regs.CMPA.half.CMPA = 500;
                                            // adjust duty for output EPWM2A & EPWM2B
    EPwm2Regs.CMPB = 250;
                                            // adjust point-in-time for ADCSOC trigger
```

# 3.3.6 Controlling Dual 3-Phase Inverters for Motors (ACI and PMSM)

The idea of multiple modules controlling a single power stage can be extended to the 3-phase Inverter case. In such a case, six switching elements can be controlled using three PWM modules, one for each leg of the inverter. Each leg must switch at the same frequency and all legs must be synchronized. A master + two slaves configuration can easily address this requirement. Figure 3-60 shows how six PWM modules can control two independent 3-phase Inverters; each running a motor.

As in the cases shown in the previous sections, we have a choice of running each inverter at a different frequency (module 1 and module 4 are masters as in Figure 3-60), or both inverters can be synchronized by using one master (module 1) and five slaves. In this case, the frequency of modules 4, 5, and 6 (all equal) can be integer multiples of the frequency for modules 1, 2, 3 (also all equal).



# Figure 3-60. Control of Dual 3-Phase Inverter Stages as Is Commonly Used in Motor Control





# Example 3-11. Code Snippet for Configuration in Figure 3-60

```
// Configuration
// Initialization Time
//===================// EPWM Module 1 config
                                                   // Period = 1600 TBCLK counts
    EPwmlReqs.TBPRD = 800;
    EPwmlRegs.TBPHS.half.TBPHS = 0;
                                                   // Set Phase register to zero
    EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN;
                                                   // Symmetrical mode
    EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE;
                                                   // Master module
    EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
    EPwmlRegs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO;
                                                   // Sync down-stream module
    EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
    EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
    EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
                                                   // load on CTR=Zero
    EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;
                                                   // load on CTR=Zero
    EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
                                                   // set actions for EPWM1A
    EPwmlRegs.AQCTLA.bit.CAD = AQ_CLEAR;
    EPwm1Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;
                                                       // enable Dead-band module
                                                    // Active Hi complementary
    EPwmlRegs.DBCTL.bit.POLSEL = DB_ACTV_HIC;
                                                   // FED = 50 TBCLKs
    EPwmlRegs.DBFED = 50;
    EPwmlRegs.DBRED = 50;
                                                    // RED = 50 TBCLKs
// EPWM Module 2 config
    EPwm2Regs.TBPRD = 800;
                                                   // Period = 1600 TBCLK counts
    EPwm2Regs.TBPHS.half.TBPHS = 0;
                                                   // Set Phase register to zero
    EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN;
                                                   // Symmetrical mode
    EPwm2Reqs.TBCTL.bit.PHSEN = TB ENABLE;
                                                   // Slave module
    EPwm2Regs.TBCTL.bit.PRDLD = TB_SHADOW;
    EPwm2Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN;
                                                   // sync flow-through
    EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
    EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
                                                   // load on CTR=Zero
    EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
    EPwm2Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;
                                                   // load on CTR=Zero
    EPwm2Regs.AQCTLA.bit.CAU = AQ_SET;
                                                   // set actions for EPWM2A
    EPwm2Regs.AQCTLA.bit.CAD = AQ_CLEAR;
    EPwm2Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;
                                                       // enable Dead-band module
    EPwm2Regs.DBCTL.bit.POLSEL = DB_ACTV_HIC;
                                                    // Active Hi complementary
    EPwm2Regs.DBFED = 50;
                                                   // FED = 50 TBCLKs
                                                   // RED = 50 TBCLKs
    EPwm2Regs.DBRED = 50;
// EPWM Module 3 config
    EPwm3Regs.TBPRD = 800;
                                                   // Period = 1600 TBCLK counts
    EPwm3Regs.TBPHS.half.TBPHS = 0;
                                                   // Set Phase register to zero
    EPwm3Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN;
                                                   // Symmetrical mode
    EPwm3Regs.TBCTL.bit.PHSEN = TB_ENABLE;
                                                   // Slave module
    EPwm3Regs.TBCTL.bit.PRDLD = TB_SHADOW;
    EPwm3Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN;
                                                   // sync flow-through
    EPwm3Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
    EPwm3Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
                                                   // load on CTR=Zero
    EPwm3Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
    EPwm3Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;
                                                   // load on CTR=Zero
    EPwm3Regs.AQCTLA.bit.CAU = AQ_SET;
                                                   // set actions for EPWM3A
    EPwm3Regs.AQCTLA.bit.CAD = AQ_CLEAR;
    EPwm3Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;
                                                       // enable Dead-band module
    EPwm3Regs.DBCTL.bit.POLSEL = DB_ACTV_HIC;
                                                   // Active Hi complementary
    EPwm3Regs.DBFED = 50;
                                                   // FED = 50 TBCLKs
                                                    // RED = 50 TBCLKs
    EPwm3Regs.DBRED = 50;
// Run Time (Note: Example execution of one run-time instant)
EPwmlRegs.CMPA.half.CMPA = 500;
                                                   // adjust duty for output EPWM1A
    EPwm2Regs.CMPA.half.CMPA = 600;
                                                   // adjust duty for output EPWM2A
    EPwm3Regs.CMPA.half.CMPA = 700;
                                                   // adjust duty for output EPWM3A
```



# 3.3.7 Practical Applications Using Phase Control Between PWM Modules

So far, none of the examples have made use of the phase register (TBPHS). It has either been set to zero or its value has been a don't care. However, by programming appropriate values into TBPHS, multiple PWM modules can address another class of power topologies that rely on phase relationship between legs (or stages) for correct operation. As described in the TB module section, a PWM module can be configured to allow a SyncIn pulse to cause the TBPHS register to be loaded into the TBCTR register. To illustrate this concept, Figure 3-62 shows a master and slave module with a phase relationship of 120°; that is, the slave leads the master.





Figure 3-63 shows the associated timing waveforms for this configuration. Here, TBPRD = 600 for both master and slave. For the slave, TBPHS = 200 (that is, 200/600 X  $360^\circ = 120^\circ$ ). Whenever the master generates a Syncln pulse (CTR = PRD), the value of TBPHS = 200 is loaded into the slave TBCTR register so the slave time-base is always leading the master's time-base by 120°.



Figure 3-63. Timing Waveforms Associated With Phase Control Between 2 Modules

# 3.3.8 Controlling a 3-Phase Interleaved DC/DC Converter

A popular power topology that makes use of phase-offset between modules is shown in Figure 3-64. This system uses three PWM modules, with module 1 configured as the master. To work, the phase relationship between adjacent modules must be  $F = 120^{\circ}$ . This is achieved by setting the slave TBPHS registers 2 and 3 with values of 1/3 and 2/3 of the period value, respectively. For example, if the period register is loaded with a value of 600 counts, then TBPHS (slave 2) = 200 and TBPHS (slave 3) = 400. Both slave modules are synchronized to the master 1 module.

This concept can be extended to four or more phases, by setting the TBPHS values appropriately. The following formula gives the TBPHS values for N phases:

 $TBPHS(N,M) = (TBPRD/N) \times (--1)$ 

Where:

N = number of phases

M = PWM module number

For example, for the 3-phase case (N=3), TBPRD = 600,

 $TBPHS(3,2) = (600/3) \times (2-1) = 200$  (Phase value for Slave module 2)

TBPHS(3,3) = 400 (Phase value for Slave module 3)

Figure 3-65 shows the waveforms for the configuration in Figure 3-64.







Figure 3-64. Control of a 3-Phase Interleaved DC/DC Converter







## Example 3-12. Code Snippet for Configuration in Figure 3-64

```
// Config
// Initialization Time
// EPWM Module 1 config
EPwmlRegs.TBPRD = 450;
                                             // Period = 900 TBCLK counts
EPwmlRegs.TBPHS.half.TBPHS = 0; // Set Phase register to zero
EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetrical mode
EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE;
                                             // Master module
EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwmlRegs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO;
                                             // Sync down-stream module
EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
                                             // load on CTR=Zero
EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR=Zero
                                             // set actions for EPWM1A
EPwmlRegs.AQCTLA.bit.CAU = AQ_SET;
EPwmlRegs.AQCTLA.bit.CAD = AQ_CLEAR;
EPwmlRegs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;
                                                 // enable Dead-band module
EPwmlRegs.DBCTL.bit.POLSEL = DB_ACTV_HIC;
                                             // Active Hi complementary
EPwmlRegs.DBFED = 20;
                                             // FED = 20 TBCLKs
EPwmlRegs.DBRED = 20;
                                             // RED = 20 TBCLKs
// EPWM Module 2 config
EPwm2Regs.TBPRD = 450;
                                             // Period = 900 TBCLK counts
EPwm2Regs.TBPHS.half.TBPHS = 300;
                                             // Phase = 300/900 * 360 = 120 deg
EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetrical mode
EPwm2Regs.TBCTL.bit.PHSEN = TB_ENABLE;
                                             // Slave module
EPwm2Regs.TBCTL.bit.PHSDIR = TB_DOWN;
                                             // Count DOWN on sync (=120 deg)
EPwm2Regs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwm2Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN;
                                             // sync flow-through
EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // load on CTR=Zero
EPwm2Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR=Zero
                                             // set actions for EPWM2A
EPwm2Regs.AQCTLA.bit.CAU = AQ_SET;
EPwm2Regs.AQCTLA.bit.CAD = AQ_CLEAR;
EPwm2Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;
                                                 // enable Dead-band module
EPwm2Regs.DBCTL.bit.POLSEL = DB_ACTV_HIC;
                                             // Active Hi Complementary
                                             // FED = 20 TBCLKs
EPwm2Regs.DBFED = 20;
                                             // RED = 20 TBCLKs
EPwm2Regs.DBRED = 20;
// EPWM Module 3 config
EPwm3Regs.TBPRD = 450;
                                             // Period = 900 TBCLK counts
EPwm3Regs.TBPHS.half.TBPHS = 300;
                                             // Phase = 300/900 * 360 = 120 deg
EPwm3Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; // Symmetrical mode
EPwm3Regs.TBCTL.bit.PHSEN = TB_ENABLE;
                                             // Slave module
EPwm2Regs.TBCTL.bit.PHSDIR = TB_UP;
                                             // Count UP on sync (=240 deg)
EPwm3Regs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwm3Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN;
                                             // sync flow-through
EPwm3Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwm3Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwm3Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
                                             // load on CTR=Zero
EPwm3Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // load on CTR=Zero
EPwm3Regs.AQCTLA.bit.CAU = AQ_SET;
                                             // set actions for EPWM3Ai
EPwm3Regs.AQCTLA.bit.CAD = AQ_CLEAR;
EPwm3Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;
                                                 // enable Dead-band module
                                             // Active Hi complementary
EPwm3Regs.DBCTL.bit.POLSEL = DB_ACTV_HIC;
EPwm3Regs.DBFED = 20;
                                             // FED = 20 TBCLKs
EPwm3Regs.DBRED = 20;
                                             // RED = 20 TBCLKs
// Run Time (Note: Example execution of one run-time instant)
// adjust duty for output EPWM1A
EPwmlRegs.CMPA.half.CMPA = 285;
EPwm2Regs.CMPA.half.CMPA = 285;
                                             // adjust duty for output EPWM2A
EPwm3Regs.CMPA.half.CMPA = 285;
                                             // adjust duty for output EPWM3A
```



# 3.3.9 Controlling Zero Voltage Switched Full Bridge (ZVSFB) Converter

The example given in Figure 3-66 assumes a static or constant phase relationship between legs (modules). In such a case, control is achieved by modulating the duty cycle. It is also possible to dynamically change the phase value on a cycle-by-cycle basis. This feature lends itself to controlling a class of power topologies known as *phase-shifted full bridge*, or *zero voltage switched full bridge*. Here the controlled parameter is not duty cycle (this is kept constant at approximately 50 percent); instead it is the phase relationship between legs. Such a system can be implemented by allocating the resources of two PWM modules to control a single power stage, which in turn requires control of four switching elements. Figure 3-67 shows a master/slave module combination synchronized together to control a full H-bridge. In this case, both master and slave modules are required to switch at the same PWM frequency. The phase is controlled by using the slave's phase register (TBPHS). The master's phase register is not used and therefore can be initialized to zero.











# Example 3-13. Code Snippet for Configuration in Figure 3-66

```
// Config
// Initialization Time
// EPWM Module 1 config
EPwmlRegs.TBPRD = 1200;
                                                       // Period = 1201 TBCLK counts
EPwmlRegs.CMPA = 600;
                                                       // Set 50% fixed duty for EPWM1A
EPwmlRegs.TBPHS.half.TBPHS = 0;
                                                       // Set Phase register to zero
EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
                                                      // Asymmetrical mode
EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE;
                                                      // Master module
EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwmlRegs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO;
                                                       // Sync down-stream module
EPwmlRegs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwmlRegs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
                                                       // load on CTR=Zero
EPwmlRegs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;
                                                       // load on CTR=Zero
EPwmlRegs.AQCTLA.bit.ZRO = AQ_SET;
                                                       // set actions for EPWM1A
EPwmlRegs.AQCTLA.bit.CAU = AQ_CLEAR;
                                                           // enable Dead-band module
EPwm1Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;
EPwmlRegs.DBCTL.bit.POLSEL = DB_ACTV_HIC;
                                                       // Active Hi complementary
                                                       // FED = 50 TBCLKs initially
EPwmlRegs.DBFED = 50;
EPwmlRegs.DBRED = 70;
                                                       // RED = 70 TBCLKs initially
// EPWM Module 2 config
                                                       // Period = 1201 TBCLK counts
EPwm2Regs.TBPRD = 1200;
EPwm2Regs.CMPA.half.CMPA = 600;
                                                       // Set 50% fixed duty EPWM2A
EPwm2Regs.TBPHS.half.TBPHS = 0;
                                                      // Set Phase register to zero initially
EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
                                                       // Asymmetrical mode
EPwm2Regs.TBCTL.bit.PHSEN = TB_ENABLE;
                                                       // Slave module
EPwm2Regs.TBCTL.bit.PRDLD = TB_SHADOW;
EPwm2Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN;
                                                       // sync flow-through
EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
                                                      // load on CTR=Zero
EPwm2Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;
                                                      // load on CTR=Zero
EPwm2Regs.AQCTLA.bit.ZRO = AQ_SET;
                                                      // set actions for EPWM2A
EPwm2Regs.AQCTLA.bit.CAU = AQ_CLEAR;
EPwm2Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;
                                                          // enable Dead-band module
                                                      // Active Hi complementary
EPwm2Regs.DBCTL.bit.POLSEL = DB_ACTV_HIC;
EPwm2Regs.DBFED = 30;
                                                      // FED = 30 TBCLKs initially
EPwm2Regs.DBRED = 40;
                                                      // RED = 40 TBCLKs initially
// Run Time (Note: Example execution of one run-time instant)
EPwm2Regs.TBPHS = 1200-300;
                                                      // Set Phase reg to 300/1200 * 360 = 90 deg
EPwmlRegs.DBFED = FED1_NewValue;
                                                      // Update ZVS transition interval
EPwmlRegs.DBRED = RED1_NewValue;
                                                      // Update ZVS transition interval
EPwm2Regs.DBFED = FED2_NewValue;
                                                      // Update ZVS transition interval
EPwm2Regs.DBRED = RED2_NewValue;
                                                      // Update ZVS transition interval
EPwmlRegs.CMPB = 200;
                                                      // adjust point-in-time for ADCSOC trigger
```

# 3.3.10 Controlling a Peak Current Mode Controlled Buck Module

Peak current control techniques offer a number of benefits like automatic over current limiting, fast correction for input voltage variations and reducing magnetic saturation. Figure 3-68 shows the use of ePWM1A along with the on-chip analog comparator for buck converter topology. The output current is sensed through a current sense resistor and fed to the positive terminal of the on-chip comparator. The internal programmable 10-bit DAC can be used to provide a reference peak current at the negative



terminal of the comparator. Alternatively, an external reference could be connected at this input. The comparator output is an input to the Digital compare sub-module. The ePWM module is configured in such a way so as to trip the ePWM1A output as soon as the sensed current reaches the peak reference value. A cycle-by-cycle trip mechanism is used. Figure 3-69 shows the waveforms generated by the configuration.







# Example 3-14. Code Snippet for Configuration in Figure 3-68

```
//------
// Config //
// Initialization Time
EPwmlRegs.TBPRD = 300;
                                                  // (200 KHz @ 60MHz clock)
// Period = 300 TBCLK counts
EPwmlRegs.TBPHS.half.TBPHS = 0;
                                                  // Set Phase register to zero
EPwmlRegs.TBCTL.bit.CTRMODE = TB_COUNT_UP;
                                                 // Asymmetrical mode
EPwmlRegs.TBCTL.bit.PHSEN = TB_DISABLE;
                                                  // Phase loading disabled
EPwmlRegs.TBCTL.bit.HSPCLKDIV = TB_DIV1;
                                                 // Clock ratio to SYSCLKOUT
EPwmlRegs.TBCTL.bit.CLKDIV = TB_DIV1;
EPwmlRegs.TBCTL.bit.PRDLD = TB_SHADOW;
PwmlRegs.AQCTLA.bit.ZRO = AQ_SET;
                                                  // Set PWM1A on Zero
                                                  // Define an event (DCAEVT2) based on
Comparator 1 Output EPwmlRegs.DCTRIPSEL.bit.DCAHCOMPSEL = DC_COMP1OUT;
                                                                 // DCAH = Comparator
1 output
EPwmlRegs.TZDCSEL.bit.DCAEVT2 = TZ_DCAH_HI;
                                                  // DCAEVT2 = DCAH high(will become
active
                                                  // as Comparator output goes high)
                                                  // DCAEVT2 = DCAEVT2 (not filtered)
EPwm1Regs.DCACTL.bit.EVT2SRCSEL = DC_EVT2;
EPwmlRegs.DCACTL.bit.EVT2FRCSYNCSEL = DC_EVT_ASYNC;
                                                  // Take async path // Enable DCAEVT2 as
a one shot trip source
                                                  // Note: DCxEVT1 events can be defined
as one-shot.
                                                  // DCxEVT2 events can be defined as
cycle-by-
cycle. EPwmlRegs.TZSEL.bit.DCAEVT2 = 1;
                                                        // What do we want the DCAEVT1
and DCBEVT1 events to do?
                                                  // DCAEVTx events can force EPWMxA //
DCBEVTx events can force EPWMxB
EPwmlRegs.TZCTL.bit.TZA = TZ_FORCE_LO;
                                                  // EPWM1A will go low
// Run Time
Adjust reference peak current to Comparator 1 negative input
```

# 3.4 Registers

This chapter includes the register layouts and bit description for the submodules.

## 3.4.1 Time-Base Submodule Registers

Figure 3-70 through Figure 3-74 and Table 3-22 through Table 3-26 provide the time-base register definitions.

#### Figure 3-70. Time-Base Period Register (TBPRD)

| 15 |       | 0 |
|----|-------|---|
|    | TBPRD |   |
|    | R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-22. Time-Base Period Register (TBPRD) Field Descriptions

| Bits | Name  | Value | Description                                                                                                                                                                                                                                                       |
|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | TBPRD | 0000- | These bits determine the period of the time-base counter. This sets the PWM frequency.                                                                                                                                                                            |
|      |       | FFFFh | Shadowing of this register is enabled and disabled by the TBCTL[PRDLD] bit. By default this register is shadowed.                                                                                                                                                 |
|      |       |       | <ul> <li>If TBCTL[PRDLD] = 0, then the shadow is enabled and any write or read will automatically go to<br/>the shadow register. In this case, the active register will be loaded from the shadow register<br/>when the time-base counter equals zero.</li> </ul> |
|      |       |       |                                                                                                                                                                                                                                                                   |
|      |       |       | <ul> <li>The active and shadow registers share the same memory map address.</li> </ul>                                                                                                                                                                            |

# Figure 3-71. Time-Base Phase Register (TBPHS)

| 15 0  |
|-------|
| TBPHS |
| R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bits | Name  | Value     | Description                                                                                                                                                                                                                                                                                         |  |
|------|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15-0 | TBPHS | 0000-FFFF | These bits set time-base counter phase of the selected ePWM relative to the time-base that is supplying the synchronization input signal.                                                                                                                                                           |  |
|      |       |           | <ul> <li>If TBCTL[PHSEN] = 0, then the synchronization event is ignored and the time-base counter is<br/>not loaded with the phase.</li> </ul>                                                                                                                                                      |  |
|      |       |           | <ul> <li>If TBCTL[PHSEN] = 1, then the time-base counter (TBCTR) will be loaded with the phase<br/>(TBPHS) when a synchronization event occurs. The synchronization event can be initiated by<br/>the input synchronization signal (EPWMxSYNCI) or by a software forced synchronization.</li> </ul> |  |

#### Figure 3-72. Time-Base Counter Register (TBCTR)

| 15 0  |
|-------|
| TBCTR |
| R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-24. Time-Base Counter Register (TBCTR) Field Descriptions

| Bit | Name    | Value         | Description                                                   |
|-----|---------|---------------|---------------------------------------------------------------|
| 15- | ) TBCTR | 0000-<br>FFFF | Reading these bits gives the current time-base counter value. |



| Bits | Name | Value | Description                                                                                                                                                                                                    |
|------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |       | Writing to these bits sets the current time-base counter value. The update happens as soon as the write occurs; the write is NOT synchronized to the time-base clock (TBCLK) and the register is not shadowed. |

# Table 3-24. Time-Base Counter Register (TBCTR) Field Descriptions (continued)

# Figure 3-73. Time-Base Control Register (TBCTL)

| 15         | 14      | 13     | 12     |       | 10        | 9       | 8 |  |
|------------|---------|--------|--------|-------|-----------|---------|---|--|
| FREE, SOFT |         | PHSDIR | CLKDIV |       | HSPCLKDIV |         |   |  |
| R/W-0      |         | R/W-0  | R/W-0  |       | R/W-0,0,1 |         |   |  |
| 7          | 6       | 5      | 4      | 3     | 2         | 1       | 0 |  |
| HSPCLKDIV  | SWFSYNC | SYNC   | OSEL   | PRDLD | PHSEN     | CTRMODE |   |  |
| R/W-0,0,1  | R/W-0   | R/W    | /-0    | R/W-0 | R/W-0     | R/W-11  |   |  |
|            |         |        |        |       |           |         |   |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 3-25. Time-Base Control Register (TBCTL) Field Descriptions

| Bit   | Field      | Value | Description                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | FREE, SOFT |       | Emulation Mode Bits. These bits select the behavior of the ePWM time-base counter during emulation events:                                                                                                                                                                                                                                                             |
|       |            | 00    | Stop after the next time-base counter increment or decrement                                                                                                                                                                                                                                                                                                           |
|       |            | 01    | Stop when counter completes a whole cycle:                                                                                                                                                                                                                                                                                                                             |
|       |            |       | • Up-count mode: stop when the time-base counter = period (TBCTR = TBPRD)                                                                                                                                                                                                                                                                                              |
|       |            |       | • Down-count mode: stop when the time-base counter = 0x0000 (TBCTR = 0x0000)                                                                                                                                                                                                                                                                                           |
|       |            |       | • Up-down-count mode: stop when the time-base counter = 0x0000 (TBCTR = 0x0000)                                                                                                                                                                                                                                                                                        |
|       |            | 1X    | Free run                                                                                                                                                                                                                                                                                                                                                               |
| 13    | PHSDIR     |       | Phase Direction Bit.                                                                                                                                                                                                                                                                                                                                                   |
|       |            |       | This bit is only used when the time-base counter is configured in the up-down-count mode. The PHSDIR bit indicates the direction the time-base counter (TBCTR) will count after a synchronization event occurs and a new phase value is loaded from the phase (TBPHS) register. This is irrespective of the direction of the counter before the synchronization event. |
|       |            |       | In the up-count and down-count modes this bit is ignored.                                                                                                                                                                                                                                                                                                              |
|       |            | 0     | Count down after the synchronization event.                                                                                                                                                                                                                                                                                                                            |
|       |            | 1     | Count up after the synchronization event.                                                                                                                                                                                                                                                                                                                              |
| 12:10 | CLKDIV     |       | Time-base Clock Prescale Bits                                                                                                                                                                                                                                                                                                                                          |
|       |            |       | These bits determine part of the time-base clock prescale value.<br>TBCLK = SYSCLKOUT / (HSPCLKDIV × CLKDIV)                                                                                                                                                                                                                                                           |
|       |            | 000   | /1 (default on reset)                                                                                                                                                                                                                                                                                                                                                  |
|       |            | 001   | /2                                                                                                                                                                                                                                                                                                                                                                     |
|       |            | 010   | /4                                                                                                                                                                                                                                                                                                                                                                     |
|       |            | 011   | /8                                                                                                                                                                                                                                                                                                                                                                     |
|       |            | 100   | /16                                                                                                                                                                                                                                                                                                                                                                    |
|       |            | 101   | /32                                                                                                                                                                                                                                                                                                                                                                    |
|       |            | 110   | /64                                                                                                                                                                                                                                                                                                                                                                    |
|       |            | 111   | /128                                                                                                                                                                                                                                                                                                                                                                   |



| Bit | Field     | Value | Description                                                                                                                                                                                                                                                                                 |
|-----|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:7 | HSPCLKDIV |       | High Speed Time-base Clock Prescale Bits                                                                                                                                                                                                                                                    |
|     |           |       | These bits determine part of the time-base clock prescale value.<br>TBCLK = SYSCLKOUT / (HSPCLKDIV × CLKDIV)                                                                                                                                                                                |
|     |           |       | This divisor emulates the HSPCLK in the TMS320x281x system as used on the Event Manager (EV) peripheral.                                                                                                                                                                                    |
|     |           | 000   | /1                                                                                                                                                                                                                                                                                          |
|     |           | 001   | /2 (default on reset)                                                                                                                                                                                                                                                                       |
|     |           | 010   | /4                                                                                                                                                                                                                                                                                          |
|     |           | 011   | /6                                                                                                                                                                                                                                                                                          |
|     |           | 100   | /8                                                                                                                                                                                                                                                                                          |
|     |           | 101   | /10                                                                                                                                                                                                                                                                                         |
|     |           | 110   | /12                                                                                                                                                                                                                                                                                         |
|     |           | 111   | /14                                                                                                                                                                                                                                                                                         |
| 6   | SWFSYNC   |       | Software Forced Synchronization Pulse                                                                                                                                                                                                                                                       |
|     |           | 0     | Writing a 0 has no effect and reads always return a 0.                                                                                                                                                                                                                                      |
|     |           | 1     | Writing a 1 forces a one-time synchronization pulse to be generated.                                                                                                                                                                                                                        |
|     |           |       | This event is ORed with the EPWMxSYNCI input of the ePWM module.                                                                                                                                                                                                                            |
|     |           |       | SWFSYNC is valid (operates) only when EPWMxSYNCI is selected by SYNCOSEL = 00.                                                                                                                                                                                                              |
| 5:4 | SYNCOSEL  |       | Synchronization Output Select. These bits select the source of the EPWMxSYNCO signal.                                                                                                                                                                                                       |
|     |           | 00    | EPWMxSYNC:                                                                                                                                                                                                                                                                                  |
|     |           | 01    | CTR = zero: Time-base counter equal to zero (TBCTR = 0x0000)                                                                                                                                                                                                                                |
|     |           | 10    | CTR = CMPB : Time-base counter equal to counter-compare B (TBCTR = CMPB)                                                                                                                                                                                                                    |
|     |           | 11    | Disable EPWMxSYNCO signal                                                                                                                                                                                                                                                                   |
| 3   | PRDLD     |       | Active Period Register Load From Shadow Register Select                                                                                                                                                                                                                                     |
|     |           | 0     | The period register (TBPRD) is loaded from its shadow register when the time-base counter, TBCTR, is equal to zero.                                                                                                                                                                         |
|     |           |       | A write or read to the TBPRD register accesses the shadow register.                                                                                                                                                                                                                         |
|     |           | 1     | Load the TBPRD register immediately without using a shadow register.                                                                                                                                                                                                                        |
|     |           |       | A write or read to the TBPRD register directly accesses the active register.                                                                                                                                                                                                                |
| 2   | PHSEN     |       | Counter Register Load From Phase Register Enable                                                                                                                                                                                                                                            |
|     |           | 0     | Do not load the time-base counter (TBCTR) from the time-base phase register (TBPHS)                                                                                                                                                                                                         |
|     |           | 1     | Load the time-base counter with the phase register when an EPWMxSYNCI input signal occurs or when a software synchronization is forced by the SWFSYNC bit, or when a digital compare sync event occurs.                                                                                     |
| 1:0 | CTRMODE   |       | Counter Mode                                                                                                                                                                                                                                                                                |
|     |           |       | The time-base counter mode is normally configured once and not changed during normal operation. If you change the mode of the counter, the change will take effect at the next TBCLK edge and the current counter value shall increment or decrement from the value before the mode change. |
|     |           |       | These bits set the time-base counter mode of operation as follows:                                                                                                                                                                                                                          |
|     |           | 00    | Up-count mode                                                                                                                                                                                                                                                                               |
|     |           | 01    | Down-count mode                                                                                                                                                                                                                                                                             |
|     |           | 10    | Up-down-count mode                                                                                                                                                                                                                                                                          |
|     |           | 11    | Stop-freeze counter operation (default on reset)                                                                                                                                                                                                                                            |

Table 3-25. Time-Base Control Register (TBCTL) Field Descriptions (continued)



| Figure 3-74. Time-Base Status Register (TBSTS) |          |          |         |         |        |  |  |
|------------------------------------------------|----------|----------|---------|---------|--------|--|--|
| 15                                             |          |          |         |         | 8      |  |  |
|                                                |          | Reserved |         |         |        |  |  |
|                                                |          | R-0      |         |         |        |  |  |
| 7                                              |          | 3        | 2       | 1       | 0      |  |  |
|                                                | Reserved |          | CTRMAX  | SYNCI   | CTRDIR |  |  |
|                                                | R-0      |          | R/W1C-0 | R/W1C-0 | R-1    |  |  |

LEGEND: R/W = Read/Write; R = Read only; R/W1C = Read/Write 1 to clear; -n = value after reset

| Bit  | Field    | Value | Description                                                                                                                                                                                           |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:3 | Reserved |       | Reserved                                                                                                                                                                                              |
| 2    | CTRMAX   |       | Time-Base Counter Max Latched Status Bit                                                                                                                                                              |
|      |          | 0     | Reading a 0 indicates the time-base counter never reached its maximum value. Writing a 0 will have no effect.                                                                                         |
|      |          | 1     | Reading a 1 on this bit indicates that the time-base counter reached the max value 0xFFFF. Writing a 1 to this bit will clear the latched event.                                                      |
| 1    | SYNCI    |       | Input Synchronization Latched Status Bit                                                                                                                                                              |
|      |          | 0     | Writing a 0 will have no effect. Reading a 0 indicates no external synchronization event has occurred.                                                                                                |
|      |          | 1     | Reading a 1 on this bit indicates that an external synchronization event has occurred (EPWMxSYNCI). Writing a 1 to this bit will clear the latched event.                                             |
| 0    | CTRDIR   |       | Time-Base Counter Direction Status Bit. At reset, the counter is frozen; therefore, this bit has no meaning. To make this bit meaningful, you must first set the appropriate mode via TBCTL[CTRMODE]. |
|      |          | 0     | Time-Base Counter is currently counting down.                                                                                                                                                         |
|      |          | 1     | Time-Base Counter is currently counting up.                                                                                                                                                           |

#### Table 3-26. Time-Base Status Register (TBSTS) Field Descriptions

# 3.4.2 Counter-Compare Submodule Registers

Figure 3-75 through Figure 3-77 and Table 3-27 through Table 3-29 illustrate the counter-compare submodule control and status registers.

# Figure 3-75. Counter-Compare A Register (CMPA)

| 15 | 0     |  |
|----|-------|--|
| (  | СМРА  |  |
| F  | R/W-0 |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bits | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | CMPA | The value in the active CMPA register is continuously compared to the time-base counter (TBCTR). When<br>the values are equal, the counter-compare module generates a "time-base counter equal to counter<br>compare A" event. This event is sent to the action-qualifier where it is qualified and converted it into one<br>or more actions. These actions can be applied to either the EPWMxA or the EPWMxB output depending<br>on the configuration of the AQCTLA and AQCTLB registers. The actions that can be defined in the<br>AQCTLA and AQCTLB registers include: |
|      |      | Do nothing; the event is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|      |      | Clear: Pull the EPWMxA and/or EPWMxB signal low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|      |      | <ul> <li>Set: Pull the EPWMxA and/or EPWMxB signal high</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      |      | Toggle the EPWMxA and/or EPWMxB signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |      | Shadowing of this register is enabled and disabled by the CMPCTL[SHDWAMODE] bit. By default this register is shadowed.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |      | <ul> <li>If CMPCTL[SHDWAMODE] = 0, then the shadow is enabled and any write or read will automatically<br/>go to the shadow register. In this case, the CMPCTL[LOADAMODE] bit field determines which event<br/>will load the active register from the shadow register.</li> </ul>                                                                                                                                                                                                                                                                                         |
|      |      | <ul> <li>Before a write, the CMPCTL[SHDWAFULL] bit can be read to determine if the shadow register is<br/>currently full.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|      |      | <ul> <li>If CMPCTL[SHDWAMODE] = 1, then the shadow register is disabled and any write or read will go directly to the active register, that is the register actively controlling the hardware.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                 |
|      |      | • In either mode, the active and shadow registers share the same memory map address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

# Figure 3-76. Counter-Compare B Register (CMPB)

| 15    | 0 |
|-------|---|
| СМРВ  |   |
| R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

TEXAS INSTRUMENTS

www.ti.com

| Bits | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | СМРВ | <ul> <li>The value in the active CMPB register is continuously compared to the time-base counter (TBCTR). When the values are equal, the counter-compare module generates a "time-base counter equal to counter compare B" event. This event is sent to the action-qualifier where it is qualified and converted it into one or more actions. These actions can be applied to either the EPWMxA or the EPWMxB output depending on the configuration of the AQCTLA and AQCTLB registers. The actions that can be defined in the AQCTLA and AQCTLB registers include:</li> <li>Do nothing. event is ignored.</li> </ul> |
|      |      | Clear: Pull the EPWMxA and/or EPWMxB signal low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      |      | Set: Pull the EPWMxA and/or EPWMxB signal high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      |      | <ul> <li>Toggle the EPWMxA and/or EPWMxB signal</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |      | Shadowing of this register is enabled and disabled by the CMPCTL[SHDWBMODE] bit. By default this register is shadowed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      |      | <ul> <li>If CMPCTL[SHDWBMODE] = 0, then the shadow is enabled and any write or read will automatically go to the shadow register. In this case, the CMPCTL[LOADBMODE] bit field determines which even will load the active register from the shadow register:</li> </ul>                                                                                                                                                                                                                                                                                                                                              |
|      |      | <ul> <li>Before a write, the CMPCTL[SHDWBFULL] bit can be read to determine if the shadow register is<br/>currently full.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |      | • If CMPCTL[SHDWBMODE] = 1, then the shadow register is disabled and any write or read will go directly to the active register, that is the register actively controlling the hardware.                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |      | • In either mode, the active and shadow registers share the same memory map address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Table 3-28. Counter-Compare B Register (CMPB) Field Descriptions

Registers



Registers

|          | Figure 3-77. Counter-Compare Control Register (CMPCTL) |           |           |       |  |       |      |  |  |  |
|----------|--------------------------------------------------------|-----------|-----------|-------|--|-------|------|--|--|--|
| 15       |                                                        | 9         | 8         |       |  |       |      |  |  |  |
|          |                                                        | SHDWBFULL | SHDWAFULL |       |  |       |      |  |  |  |
|          | R-0                                                    |           |           |       |  |       | R-0  |  |  |  |
| 7        | 6 5 4 3 2                                              |           |           |       |  | 1     | 0    |  |  |  |
| Reserved | SHDWBMODE Reserved SHDWAMODE LOADBMODE                 |           |           |       |  | LOADA | MODE |  |  |  |
| R-0      | R/W-0                                                  | R-0       | R/W-0     | R/W-0 |  | R/W-0 |      |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Name Bits Value Description 15-10 Reserved Reserved SHDWBFULL Counter-compare B (CMPB) Shadow Register Full Status Flag 9 This bit self clears once a load-strobe occurs. 0 CMPB shadow FIFO not full yet 1 Indicates the CMPB shadow FIFO is full; a CPU write will overwrite current shadow value. SHDWAFULL Counter-compare A (CMPA) Shadow Register Full Status Flag 8 The flag bit is set when a 16-bit write to CMPA register is made. This bit self clears once a load-strobe occurs. 0 CMPA shadow FIFO not full yet 1 Indicates the CMPA shadow FIFO is full, a CPU write will overwrite the current shadow value. 7 Reserved Reserved SHDWBMODE 6 Counter-compare B (CMPB) Register Operating Mode 0 Shadow mode. Operates as a double buffer. All writes via the CPU access the shadow register. 1 Immediate mode. Only the active compare B register is used. All writes and reads directly access the active register for immediate compare action. 5 Reserved Reserved SHDWAMODE 4 Counter-compare A (CMPA) Register Operating Mode 0 Shadow mode. Operates as a double buffer. All writes via the CPU access the shadow register. 1 Immediate mode. Only the active compare register is used. All writes and reads directly access the active register for immediate compare action LOADBMODE 3-2 Active Counter-Compare B (CMPB) Load From Shadow Select Mode This bit has no effect in immediate mode (CMPCTL[SHDWBMODE] = 1). 00 Load on CTR = Zero: Time-base counter equal to zero (TBCTR = 0x0000) 01 Load on CTR = PRD: Time-base counter equal to period (TBCTR = TBPRD) 10 Load on either CTR = Zero or CTR = PRD 11 Freeze (no loads possible) Active Counter-Compare A (CMPA) Load From Shadow Select Mode. 1-0 LOADAMODE This bit has no effect in immediate mode (CMPCTL[SHDWAMODE] = 1). 00 Load on CTR = Zero: Time-base counter equal to zero (TBCTR = 0x0000) 01 Load on CTR = PRD: Time-base counter equal to period (TBCTR = TBPRD) 10 Load on either CTR = Zero or CTR = PRD

#### Table 3-29. Counter-Compare Control Register (CMPCTL) Field Descriptions

| Figure 3-78.    | Counter-Com | pare A Mirror | Register | (CMPAM) |
|-----------------|-------------|---------------|----------|---------|
| i igui o o i o. |             |               | Register |         |

Freeze (no loads possible)

| LEGEND: R/W = | Read/Write: F | R = Read of | $nlv \cdot -n = v$ | alue after re | eset |
|---------------|---------------|-------------|--------------------|---------------|------|

11

15

0

CMPA R/W-0



| Bit  | Field | Value      | Description                                                                                                                                                                                                                                                                                                                     |
|------|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | СМРА  | 0000-FFFFh | CMPA and CMPAM can both be used to access the counter-compare A value. The only difference is that the mirror register always reads back the active value.                                                                                                                                                                      |
|      |       |            | By default writes to this register are shadowed. Unlike the CMPA register, reads of CMPAM always return the active register value. Shadowing is enabled and disabled by the CMPCTL[SHDWAMODE] bit.                                                                                                                              |
|      |       |            | <ul> <li>If CMPCTL[SHDWAMODE] = 0, then the shadow is enabled and any write will automatically go<br/>to the shadow register. All reads will reflect the active register value. In this case, the<br/>CMPCTL[LOADAMODE] bit field determines which event will load the active register from the<br/>shadow register.</li> </ul> |
|      |       |            | <ul> <li>Before a write, the CMPCTL[SHDWAFULL] bit can be read to determine if the shadow register<br/>is currently full.</li> </ul>                                                                                                                                                                                            |
|      |       |            | <ul> <li>If CMPCTL[SHDWAMODE] = 1, then the shadow register is disabled and any write will go directly to the active register, that is the register actively controlling the hardware.</li> </ul>                                                                                                                               |

### Table 3-30. Counter-Compare A Mirror Register (CMPAM) Field Descriptions

# 3.4.3 Action-Qualifier Submodule Registers

Figure 3-79 through Figure 3-82 and Table 3-31 through Table 3-34 provide the action-qualifier submodule register definitions.

| 15  |       |       | 12  | 11    | 10  | 9         | 8  |
|-----|-------|-------|-----|-------|-----|-----------|----|
|     | Rese  | erved |     | CI    | BD  | CBU       |    |
|     | R-0   |       |     | R/W-0 |     | R/W-0     |    |
| 7   | 6     | 5     | 4   | 3     | 2   | 1         | 0  |
| CA  | CAD   |       | CAU |       | PRD |           | 80 |
| R/V | R/W-0 |       | W-0 | R/W-0 |     | R/W-0 R/V |    |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 3-31. Action-Qualifier Output A Control Register (AQCTLA) Field Descriptions

| Bits  | Name     | Value | Description                                                                                        |
|-------|----------|-------|----------------------------------------------------------------------------------------------------|
| 15-12 | Reserved |       | Reserved                                                                                           |
| 11-10 | CBD      |       | Action when the time-base counter equals the active CMPB register and the counter is decrementing. |
|       |          | 00    | Do nothing (action disabled)                                                                       |
|       |          | 01    | Clear: force EPWMxA output low.                                                                    |
|       |          | 10    | Set: force EPWMxA output high.                                                                     |
|       |          | 11    | Toggle EPWMxA output: low output signal will be forced high, and a high signal will be forced low. |
| 9-8   | CBU      |       | Action when the counter equals the active CMPB register and the counter is incrementing.           |
|       |          | 00    | Do nothing (action disabled)                                                                       |
|       |          | 01    | Clear: force EPWMxA output low.                                                                    |
|       |          | 10    | Set: force EPWMxA output high.                                                                     |
|       |          | 11    | Toggle EPWMxA output: low output signal will be forced high, and a high signal will be forced low. |
| 7-6   | CAD      |       | Action when the counter equals the active CMPA register and the counter is decrementing.           |
|       |          | 00    | Do nothing (action disabled)                                                                       |
|       |          | 01    | Clear: force EPWMxA output low.                                                                    |
|       |          | 10    | Set: force EPWMxA output high.                                                                     |
|       |          | 11    | Toggle EPWMxA output: low output signal will be forced high, and a high signal will be forced low. |

| Bits | Name | Value | Description                                                                                                               |
|------|------|-------|---------------------------------------------------------------------------------------------------------------------------|
| 5-4  | CAU  |       | Action when the counter equals the active CMPA register and the counter is incrementing.                                  |
|      |      | 00    | Do nothing (action disabled)                                                                                              |
|      |      | 01    | Clear: force EPWMxA output low.                                                                                           |
|      |      | 10    | Set: force EPWMxA output high.                                                                                            |
|      |      | 11    | Toggle EPWMxA output: low output signal will be forced high, and a high signal will be forced low.                        |
| 3-2  | PRD  |       | Action when the counter equals the period.                                                                                |
|      |      |       | Note: By definition, in count up-down mode when the counter equals period the direction is defined as 0 or counting down. |
|      |      | 00    | Do nothing (action disabled)                                                                                              |
|      |      | 01    | Clear: force EPWMxA output low.                                                                                           |
|      |      | 10    | Set: force EPWMxA output high.                                                                                            |
|      |      | 11    | Toggle EPWMxA output: low output signal will be forced high, and a high signal will be forced low.                        |
| 1-0  | ZRO  |       | Action when counter equals zero.                                                                                          |
|      |      |       | Note: By definition, in count up-down mode when the counter equals 0 the direction is defined as 1 or counting up.        |
|      |      | 00    | Do nothing (action disabled)                                                                                              |
|      |      | 01    | Clear: force EPWMxA output low.                                                                                           |
|      |      | 10    | Set: force EPWMxA output high.                                                                                            |
|      |      | 11    | Toggle EPWMxA output: low output signal will be forced high, and a high signal will be forced low.                        |

## Table 3-31. Action-Qualifier Output A Control Register (AQCTLA) Field Descriptions (continued)

## Figure 3-80. Action-Qualifier Output B Control Register (AQCTLB)

|       |              | 12          | 11                                 | 10                        | 9                                                                                                                                                   | 8                                                                                                                                                                                     |
|-------|--------------|-------------|------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rese  | erved        |             | CI                                 | 3D                        | CE                                                                                                                                                  | 3U                                                                                                                                                                                    |
| R-0   |              |             | RΛ                                 | V-0                       | R/V                                                                                                                                                 | V-0                                                                                                                                                                                   |
| 6     | 5            | 4           | 3                                  | 2                         | 1                                                                                                                                                   | 0                                                                                                                                                                                     |
| CAD   |              | ٩U          | PRD                                |                           | ZRO                                                                                                                                                 |                                                                                                                                                                                       |
| R/W-0 |              | N-0         | R/W-0                              |                           | R/W-0                                                                                                                                               |                                                                                                                                                                                       |
|       | R<br>6<br>.D | 6 5<br>D C/ | Reserved<br>R-0<br>6 5 4<br>ND CAU | ReservedCfR-0R/V6543CAUPF | Reserved         CBD           R-0         R/W-0           6         5         4         3         2           AD         CAU         PRD         1 | Reserved         CBD         CE           R-0         R/W-0         R/W           6         5         4         3         2         1           AD         CAU         PRD         ZR |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-32. Action-Qualifier Output B Control Register (AQCTLB) Field Descriptions

| Bits  | Name     | Value | Description                                                                                        |
|-------|----------|-------|----------------------------------------------------------------------------------------------------|
| 15-12 | Reserved |       |                                                                                                    |
| 11-10 | CBD      |       | Action when the counter equals the active CMPB register and the counter is decrementing.           |
|       |          | 00    | Do nothing (action disabled)                                                                       |
|       |          | 01    | Clear: force EPWMxB output low.                                                                    |
|       |          | 10    | Set: force EPWMxB output high.                                                                     |
|       |          | 11    | Toggle EPWMxB output: low output signal will be forced high, and a high signal will be forced low. |
| 9-8   | CBU      |       | Action when the counter equals the active CMPB register and the counter is incrementing.           |
|       |          | 00    | Do nothing (action disabled)                                                                       |
|       |          | 01    | Clear: force EPWMxB output low.                                                                    |
|       |          | 10    | Set: force EPWMxB output high.                                                                     |
|       |          | 11    | Toggle EPWMxB output: low output signal will be forced high, and a high signal will be forced low. |
| 7-6   | CAD      |       | Action when the counter equals the active CMPA register and the counter is decrementing.           |
|       |          | 00    | Do nothing (action disabled)                                                                       |
|       |          | 01    | Clear: force EPWMxB output low.                                                                    |
|       |          | 10    | Set: force EPWMxB output high.                                                                     |
|       |          | 11    | Toggle EPWMxB output: low output signal will be forced high, and a high signal will be forced low. |



| Bits | Name | Value | Description                                                                                                               |
|------|------|-------|---------------------------------------------------------------------------------------------------------------------------|
| 5-4  | CAU  |       | Action when the counter equals the active CMPA register and the counter is incrementing.                                  |
|      |      | 00    | Do nothing (action disabled)                                                                                              |
|      |      | 01    | Clear: force EPWMxB output low.                                                                                           |
|      |      | 10    | Set: force EPWMxB output high.                                                                                            |
|      |      | 11    | Toggle EPWMxB output: low output signal will be forced high, and a high signal will be forced low.                        |
| 3-2  | PRD  |       | Action when the counter equals the period.                                                                                |
|      |      |       | Note: By definition, in count up-down mode when the counter equals period the direction is defined as 0 or counting down. |
|      |      | 00    | Do nothing (action disabled)                                                                                              |
|      |      | 01    | Clear: force EPWMxB output low.                                                                                           |
|      |      | 10    | Set: force EPWMxB output high.                                                                                            |
|      |      | 11    | Toggle EPWMxB output: low output signal will be forced high, and a high signal will be forced low.                        |
| 1-0  | ZRO  |       | Action when counter equals zero.                                                                                          |
|      |      |       | Note: By definition, in count up-down mode when the counter equals 0 the direction is defined as 1 or counting up.        |
|      |      | 00    | Do nothing (action disabled)                                                                                              |
|      |      | 01    | Clear: force EPWMxB output low.                                                                                           |
|      |      | 10    | Set: force EPWMxB output high.                                                                                            |
|      |      | 11    | Toggle EPWMxB output: low output signal will be forced high, and a high signal will be forced low.                        |

## Table 3-32. Action-Qualifier Output B Control Register (AQCTLB) Field Descriptions (continued)

# Figure 3-81. Action-Qualifier Software Force Register (AQSFRC)

| 15  |        |   |     |       |       |     | 8   |
|-----|--------|---|-----|-------|-------|-----|-----|
|     |        |   | Res | erved |       |     |     |
|     | R-0    |   |     |       |       |     |     |
| 7   | 6      | 5 | 4   | 3     | 2     | 1   | 0   |
| RLD | RLDCSF |   | ACT | SFB   | OTSFA | ACT | SFA |
| R/V | R/W-0  |   | R/  | N-0   | R/W-0 | RΛ  | N-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-33. Action-Qualifier Software Force Register (AQSFRC) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                        |
|------|----------|-------|--------------------------------------------------------------------------------------------------------------------|
| 15:8 | Reserved |       |                                                                                                                    |
| 7:6  | RLDCSF   |       | AQCSFRC Active Register Reload From Shadow Options                                                                 |
|      |          | 00    | Load on event counter equals zero                                                                                  |
|      |          | 01    | Load on event counter equals period                                                                                |
|      |          | 10    | Load on event counter equals zero or counter equals period                                                         |
|      |          | 11    | Load immediately (the active register is directly accessed by the CPU and is not loaded from the shadow register). |
| 5    | OTSFB    |       | One-Time Software Forced Event on Output B                                                                         |
|      |          | 0     | Writing a 0 (zero) has no effect. Always reads back a 0                                                            |
|      |          |       | This bit is auto cleared once a write to this register is complete, that is, a forced event is initiated.)         |
|      |          |       | This is a one-shot forced event. It can be overridden by another subsequent event on output B.                     |
|      |          | 1     | Initiates a single s/w forced event                                                                                |

| Bit | Field  | Value | Description                                                                                                |
|-----|--------|-------|------------------------------------------------------------------------------------------------------------|
| 4:3 | ACTSFB |       | Action when One-Time Software Force B Is invoked                                                           |
|     |        | 00    | Does nothing (action disabled)                                                                             |
|     |        | 01    | Clear (low)                                                                                                |
|     |        | 10    | Set (high)                                                                                                 |
|     |        | 11    | Toggle (Low -> High, High -> Low)                                                                          |
|     |        |       | Note: This action is not qualified by counter direction (CNT_dir)                                          |
| 2   | OTSFA  |       | One-Time Software Forced Event on Output A                                                                 |
|     |        | 0     | Writing a 0 (zero) has no effect. Always reads back a 0.                                                   |
|     |        |       | This bit is auto cleared once a write to this register is complete (that is, a forced event is initiated). |
|     |        | 1     | Initiates a single software forced event                                                                   |
| 1:0 | ACTSFA |       | Action When One-Time Software Force A Is Invoked                                                           |
|     |        | 00    | Does nothing (action disabled)                                                                             |
|     |        | 01    | Clear (low)                                                                                                |
|     |        | 10    | Set (high)                                                                                                 |
|     |        | 11    | Toggle (Low $\rightarrow$ High, High $\rightarrow$ Low)                                                    |
|     |        |       | Note: This action is not qualified by counter direction (CNT_dir)                                          |

#### Table 3-33. Action-Qualifier Software Force Register (AQSFRC) Field Descriptions (continued)



| 15 |          |      |      |      |       | 8   |  |
|----|----------|------|------|------|-------|-----|--|
|    |          | Rese | rved |      |       |     |  |
|    | R-0      |      |      |      |       |     |  |
| 7  |          | 4    | 3    | 2    | 1     | 0   |  |
|    | Reserved |      |      | CSFB |       | SFA |  |
|    | R-0      |      | R/   | V-0  | R/W-0 |     |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 3-34. Action-qualifier Continuous Software Force Register (AQCSFRC) Field Descriptions

| Bits | Name     | Value | Description                                                                                                                                                        |
|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4 | Reserved |       | Reserved                                                                                                                                                           |
| 3-2  | CSFB     |       | Continuous Software Force on Output B                                                                                                                              |
|      |          |       | In immediate mode, a continuous force takes effect on the next TBCLK edge.                                                                                         |
|      |          |       | In shadow mode, a continuous force takes effect on the next TBCLK edge after a shadow load into the active register. To configure shadow mode, use AQSFRC[RLDCSF]. |
|      |          | 00    | Forcing disabled, that is, has no effect                                                                                                                           |
|      |          | 01    | Forces a continuous low on output B                                                                                                                                |
|      |          | 10    | Forces a continuous high on output B                                                                                                                               |
|      |          | 11    | Software forcing is disabled and has no effect                                                                                                                     |
| 1-0  | CSFA     |       | Continuous Software Force on Output A                                                                                                                              |
|      |          |       | In immediate mode, a continuous force takes effect on the next TBCLK edge.                                                                                         |
|      |          |       | In shadow mode, a continuous force takes effect on the next TBCLK edge after a shadow load into the active register.                                               |
|      |          | 00    | Forcing disabled, that is, has no effect                                                                                                                           |
|      |          | 01    | Forces a continuous low on output A                                                                                                                                |
|      |          | 10    | Forces a continuous high on output A                                                                                                                               |
|      |          | 11    | Software forcing is disabled and has no effect                                                                                                                     |

Registers



www.ti.com

# 3.4.4 Dead-Band Submodule Registers

Figure 3-83 through Figure 3-85 and Table 3-35 through Table 3-37 provide the register definitions.

# Figure 3-83. Dead-Band Generator Control Register (DBCTL)

| 15        | 14        | 0  |          |    | U (    |    | 8    |
|-----------|-----------|----|----------|----|--------|----|------|
| HALFCYCLE |           |    | Reserved |    |        |    |      |
| R/W-0     | R/W-0 R-0 |    |          |    |        |    |      |
| 7         | 6         | 5  | 4        | 3  | 2      | 1  | 0    |
| Rese      | Reserved  |    | IN_MODE  |    | POLSEL |    | MODE |
| R-0       |           | R/ | N-0      | R/ | N-0    | R/ | W-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-35. Dead-Band Generator Control Register (DBCTL) Field Descriptions

| Bits | Name      | Value | Description                                                                                                                                        |
|------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | HALFCYCLE |       | Half Cycle Clocking Enable Bit:                                                                                                                    |
|      |           | 0     | Full cycle clocking enabled. The dead-band counters are clocked at the TBCLK rate.                                                                 |
|      |           | 1     | Half cycle clocking enabled. The dead-band counters are clocked at TBCLK*2.                                                                        |
| 14-6 | Reserved  |       | Reserved                                                                                                                                           |
| 5-4  | IN_MODE   |       | Dead Band Input Mode Control                                                                                                                       |
|      |           |       | Bit 5 controls the S5 switch and bit 4 controls the S4 switch shown in Figure 3-29.                                                                |
|      |           |       | This allows you to select the input source to the falling-edge and rising-edge delay.                                                              |
|      |           |       | To produce classical dead-band waveforms the default is EPWMxA In is the source for both falling and rising-edge delays.                           |
|      |           | 00    | EPWMxA In (from the action-qualifier) is the source for both falling-edge and rising-edge delay.                                                   |
|      |           | 01    | EPWMxB In (from the action-qualifier) is the source for rising-edge delayed signal.                                                                |
|      |           |       | EPWMxA In (from the action-qualifier) is the source for falling-edge delayed signal.                                                               |
|      |           | 10    | EPWMxA In (from the action-qualifier) is the source for rising-edge delayed signal.                                                                |
|      |           |       | EPWMxB In (from the action-qualifier) is the source for falling-edge delayed signal.                                                               |
|      |           | 11    | EPWMxB In (from the action-qualifier) is the source for both rising-edge delay and falling-<br>edge delayed signal.                                |
| 3-2  | POLSEL    |       | Polarity Select Control                                                                                                                            |
|      |           |       | Bit 3 controls the S3 switch and bit 2 controls the S2 switch shown in Figure 3-29.                                                                |
|      |           |       | This allows you to selectively invert one of the delayed signals before it is sent out of the dead-band submodule.                                 |
|      |           |       | The following descriptions correspond to classical upper/lower switch control as found in one leg of a digital motor control inverter.             |
|      |           |       | These assume that DBCTL[OUT_MODE] = 1,1 and DBCTL[IN_MODE] = 0,0. Other enhanced modes are also possible, but not regarded as typical usage modes. |
|      |           | 00    | Active high (AH) mode. Neither EPWMxA nor EPWMxB is inverted (default).                                                                            |
|      |           | 01    | Active low complementary (ALC) mode. EPWMxA is inverted.                                                                                           |
|      |           | 10    | Active high complementary (AHC). EPWMxB is inverted.                                                                                               |
|      |           | 11    | Active low (AL) mode. Both EPWMxA and EPWMxB are inverted.                                                                                         |

| Bits | Name     | Value | Description                                                                                                                                                                                   |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0  | OUT_MODE |       | Dead-band Output Mode Control                                                                                                                                                                 |
|      |          |       | Bit 1 controls the S1 switch and bit 0 controls the S0 switch shown in Figure 3-29.                                                                                                           |
|      |          |       | This allows you to selectively enable or bypass the dead-band generation for the falling-edge and rising-edge delay.                                                                          |
|      |          | 00    | Dead-band generation is bypassed for both output signals. In this mode, both the EPWMxA and EPWMxB output signals from the action-qualifier are passed directly to the PWM-chopper submodule. |
|      |          |       | In this mode, the POLSEL and IN_MODE bits have no effect.                                                                                                                                     |
|      |          | 01    | Disable rising-edge delay. The EPWMxA signal from the action-qualifier is passed straight through to the EPWMxA input of the PWM-chopper submodule.                                           |
|      |          |       | The falling-edge delayed signal is seen on output EPWMxB. The input signal for the delay is determined by DBCTL[IN_MODE].                                                                     |
|      |          | 10    | The rising-edge delayed signal is seen on output EPWMxA. The input signal for the delay is determined by DBCTL[IN_MODE].                                                                      |
|      |          |       | Disable falling-edge delay. The EPWMxB signal from the action-qualifier is passed straight through to the EPWMxB input of the PWM-chopper submodule.                                          |
|      |          | 11    | Dead-band is fully enabled for both rising-edge delay on output EPWMxA and falling-edge delay on output EPWMxB. The input signal for the delay is determined by DBCTL[IN_MODE].               |

## Table 3-35. Dead-Band Generator Control Register (DBCTL) Field Descriptions (continued)

## Figure 3-84. Dead-Band Generator Rising Edge Delay Register (DBRED)

| 15 |          | 10 | 9   | 8  |
|----|----------|----|-----|----|
|    | Reserved |    | DE  | L  |
|    | R-0      |    | R/W | -0 |
| 7  |          |    |     | 0  |
|    | DEL      |    |     |    |
|    | R/W-0    |    |     |    |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-36. Dead-Band Generator Rising Edge Delay Register (DBRED) Field Descriptions

| Bits  | Name     | Value | Description                              |
|-------|----------|-------|------------------------------------------|
| 15-10 | Reserved |       | Reserved                                 |
| 9-0   | DEL      |       | Rising Edge Delay Count. 10-bit counter. |

### Figure 3-85. Dead-Band Generator Falling Edge Delay Register (DBFED)

| 15 |          | 10 | 9   | 8   |
|----|----------|----|-----|-----|
|    | Reserved |    | DI  | ΞL  |
|    | R-0      |    | R/V | V-0 |
| 7  |          |    |     | 0   |
|    | DEL      |    |     |     |
|    | R/W-0    |    |     |     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-37. Dead-Band Generator Falling Edge Delay Register (DBFED) Field Descriptions

| Bits  | Name     | Description                              |
|-------|----------|------------------------------------------|
| 15-10 | Reserved | Reserved                                 |
| 9-0   | DEL      | Falling Edge Delay Count. 10-bit counter |

# 3.4.5 PWM-Chopper Submodule Control Register

Figure 3-86 and Table 3-38 provide the definitions for the PWM-chopper submodule control register.

#### Figure 3-86. PWM-Chopper Control Register (PCCTL) 15 8 11 10 CHPDUTY Reserved R-0 R/W-0 7 5 4 1 0 CHPFREQ OSHTWTH CHPEN R/W-0 R/W-0 R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bits  | Name     | Value | Description                                                |
|-------|----------|-------|------------------------------------------------------------|
| 15-11 | Reserved |       | Reserved                                                   |
| 10-8  | CHPDUTY  |       | Chopping Clock Duty Cycle                                  |
|       |          | 000   | Duty = 1/8 (12.5%)                                         |
|       |          | 001   | Duty = 2/8 (25.0%)                                         |
|       |          | 010   | Duty = 3/8 (37.5%)                                         |
|       |          | 011   | Duty = 4/8 (50.0%)                                         |
|       |          | 100   | Duty = 5/8 (62.5%)                                         |
|       |          | 101   | Duty = 6/8 (75.0%)                                         |
|       |          | 110   | Duty = 7/8 (87.5%)                                         |
|       |          | 111   | Reserved                                                   |
| 7:5   | CHPFREQ  |       | Chopping Clock Frequency                                   |
|       |          | 000   | Divide by 1 (no prescale, = 12.5 MHz at 100 MHz SYSCLKOUT) |
|       |          | 001   | Divide by 2 (6.25 MHz at 100 MHz SYSCLKOUT)                |
|       |          | 010   | Divide by 3 (4.16 MHz at 100 MHz SYSCLKOUT)                |
|       |          | 011   | Divide by 4 (3.12 MHz at 100 MHz SYSCLKOUT)                |
|       |          | 100   | Divide by 5 (2.50 MHz at 100 MHz SYSCLKOUT)                |
|       |          | 101   | Divide by 6 (2.08 MHz at 100 MHz SYSCLKOUT)                |
|       |          | 110   | Divide by 7 (1.78 MHz at 100 MHz SYSCLKOUT)                |
|       |          | 111   | Divide by 8 (1.56 MHz at 100 MHz SYSCLKOUT)                |
| 4:1   | OSHTWTH  |       | One-Shot Pulse Width                                       |
|       |          | 0000  | 1 x SYSCLKOUT / 8 wide ( = 80 nS at 100 MHz SYSCLKOUT)     |
|       |          | 0001  | 2 x SYSCLKOUT / 8 wide ( = 160 nS at 100 MHz SYSCLKOUT)    |
|       |          | 0010  | 3 x SYSCLKOUT / 8 wide ( = 240 nS at 100 MHz SYSCLKOUT)    |
|       |          | 0011  | 4 x SYSCLKOUT / 8 wide ( = 320 nS at 100 MHz SYSCLKOUT)    |
|       |          | 0100  | 5 x SYSCLKOUT / 8 wide ( = 400 nS at 100 MHz SYSCLKOUT)    |
|       |          | 0101  | 6 x SYSCLKOUT / 8 wide ( = 480 nS at 100 MHz SYSCLKOUT)    |
|       |          | 0110  | 7 x SYSCLKOUT / 8 wide ( = 560 nS at 100 MHz SYSCLKOUT)    |
|       |          | 0111  | 8 x SYSCLKOUT / 8 wide ( = 640 nS at 100 MHz SYSCLKOUT)    |
|       |          | 1000  | 9 x SYSCLKOUT / 8 wide ( = 720 nS at 100 MHz SYSCLKOUT)    |
|       |          | 1001  | 10 x SYSCLKOUT / 8 wide ( = 800 nS at 100 MHz SYSCLKOUT)   |
|       |          | 1010  | 11 x SYSCLKOUT / 8 wide ( = 880 nS at 100 MHz SYSCLKOUT)   |
|       |          | 1011  | 12 x SYSCLKOUT / 8 wide ( = 960 nS at 100 MHz SYSCLKOUT)   |
|       |          | 1100  | 13 x SYSCLKOUT / 8 wide ( = 1040 nS at 100 MHz SYSCLKOUT)  |
|       |          | 1101  | 14 x SYSCLKOUT / 8 wide ( = 1120 nS at 100 MHz SYSCLKOUT)  |
|       |          | 1110  | 15 x SYSCLKOUT / 8 wide ( = 1200 nS at 100 MHz SYSCLKOUT)  |
|       |          | 1111  | 16 x SYSCLKOUT / 8 wide ( = 1280 nS at 100 MHz SYSCLKOUT)  |

# Table 3-38. PWM-Chopper Control Register (PCCTL) Bit Descriptions



| Bits | Name  | Value | Description                            |  |
|------|-------|-------|----------------------------------------|--|
| 0    | CHPEN |       | PWM-chopping Enable                    |  |
|      |       | 0     | Disable (bypass) PWM chopping function |  |
|      |       | 1     | Enable chopping function               |  |

Table 3-38. PWM-Chopper Control Register (PCCTL) Bit Descriptions (continued)

|         |         | Figure | 3-87. Trip-Zo | ne Select Reg | gister (TZSEL) |       |       |
|---------|---------|--------|---------------|---------------|----------------|-------|-------|
| 15      | 14      | 13     | 12            | 11            | 10             | 9     | 8     |
| DCBEVT1 | DCAEVT1 | OSHT6  | OSHT5         | OSHT4         | OSHT3          | OSHT2 | OSHT1 |
| R-0     | R-0     | R/W-0  | R/W-0         | R/W-0         | R/W-0          | R/W-0 | R/W-0 |
| 7       | 6       | 5      | 4             | 3             | 2              | 1     | 0     |
| DCBEVT2 | DCAEVT2 | CBC6   | CBC5          | CBC4          | CBC3           | CBC2  | CBC1  |
| R-0     |         | R/W-0  | R/W-0         | R/W-0         | R/W-0          | R/W-0 | R/W-0 |

# 3.4.6 Trip-Zone Submodule Control and Status Registers

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-39. Trip-Zone Submodule Select Register (TZSEL) Field Descriptions

| Bits    | Name                          | Value      | Description                                                                                                                                                                                                                                                                   |
|---------|-------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ePWM m  | nodule. When<br>B outputs. Th | the event  | ble/disable. When any of the enabled pins go low, a one-shot trip event occurs for this occurs, the action defined in the TZCTL register (???) is taken on the EPWMxA and trip condition remains latched until the user clears the condition via the TZCLR register           |
| 15      | DCBEVT1                       |            | Digital Compare Output B Event 1 Select                                                                                                                                                                                                                                       |
|         |                               | 0          | Disable DCBEVT1 as one-shot-trip source for this ePWM module.                                                                                                                                                                                                                 |
|         |                               | 1          | Enable DCBEVT1 as one-shot-trip source for this ePWM module.                                                                                                                                                                                                                  |
| 14      | DCAEVT1                       |            | Digital Compare Output A Event 1 Select                                                                                                                                                                                                                                       |
|         |                               | 0          | Disable DCAEVT1 as one-shot-trip source for this ePWM module.                                                                                                                                                                                                                 |
|         |                               | 1          | Enable DCAEVT1 as one-shot-trip source for this ePWM module.                                                                                                                                                                                                                  |
| 13      | OSHT6                         |            | Trip-zone 6 (TZ6) Select                                                                                                                                                                                                                                                      |
|         |                               | 0          | Disable $\overline{TZ6}$ as a one-shot trip source for this ePWM module.                                                                                                                                                                                                      |
|         |                               | 1          | Enable TZ6 as a one-shot trip source for this ePWM module.                                                                                                                                                                                                                    |
| 12      | OSHT5                         |            | Trip-zone 5 (TZ5) Select                                                                                                                                                                                                                                                      |
|         |                               | 0          | Disable $\overline{TZ5}$ as a one-shot trip source for this ePWM module                                                                                                                                                                                                       |
|         |                               | 1          | Enable TZ5 as a one-shot trip source for this ePWM module                                                                                                                                                                                                                     |
| 11      | OSHT4                         |            | Trip-zone 4 (TZ4) Select                                                                                                                                                                                                                                                      |
|         |                               | 0          | Disable $\overline{TZ4}$ as a one-shot trip source for this ePWM module                                                                                                                                                                                                       |
|         |                               | 1          | Enable TZ4 as a one-shot trip source for this ePWM module                                                                                                                                                                                                                     |
| 10      | OSHT3                         |            | Trip-zone 3 (TZ3) Select                                                                                                                                                                                                                                                      |
|         |                               | 0          | Disable $\overline{TZ3}$ as a one-shot trip source for this ePWM module                                                                                                                                                                                                       |
|         |                               | 1          | Enable $\overline{TZ3}$ as a one-shot trip source for this ePWM module                                                                                                                                                                                                        |
| 9       | OSHT2                         |            | Trip-zone 2 (TZ2) Select                                                                                                                                                                                                                                                      |
|         |                               | 0          | Disable TZ2 as a one-shot trip source for this ePWM module                                                                                                                                                                                                                    |
|         |                               | 1          | Enable TZ2 as a one-shot trip source for this ePWM module                                                                                                                                                                                                                     |
| 8       | OSHT1                         |            | Trip-zone 1 (TZ1) Select                                                                                                                                                                                                                                                      |
|         |                               | 0          | Disable TZ1 as a one-shot trip source for this ePWM module                                                                                                                                                                                                                    |
|         |                               | 1          | Enable TZ1 as a one-shot trip source for this ePWM module                                                                                                                                                                                                                     |
| or this | ePWM modul                    | e. When th | enable/disable. When any of the enabled pins go low, a cycle-by-cycle trip event occurs<br>e event occurs, the action defined in the TZCTL register (???) is taken on the EPWMxA<br>by-cycle trip condition is automatically cleared when the time-base counter reaches zero. |
| 7       | DCBEVT2                       |            | Digital Compare Output B Event 2 Select                                                                                                                                                                                                                                       |
|         |                               | 0          | Disable DCBEVT2 as a CBC trip source for this ePWM module                                                                                                                                                                                                                     |
|         |                               | 1          | Enable DCBEVT2 as a CBC trip source for this ePWM module                                                                                                                                                                                                                      |
| 6       | DCAEVT2                       |            | Digital Compare Output A Event 2 Select                                                                                                                                                                                                                                       |
|         |                               | 0          | Disable DCAEVT2 as a CBC trip source for this ePWM module                                                                                                                                                                                                                     |
|         |                               | 1          | Enable DCAEVT2 as a CBC trip source for this ePWM module                                                                                                                                                                                                                      |

| Bits | Name | Value | Description                                                        |  |  |  |  |  |
|------|------|-------|--------------------------------------------------------------------|--|--|--|--|--|
| 5    | CBC6 |       | Trip-zone 6 (TZ6) Select                                           |  |  |  |  |  |
|      |      | 0     | Disable TZ6 as a CBC trip source for this ePWM module              |  |  |  |  |  |
|      |      | 1     | Enable TZ6 as a CBC trip source for this ePWM module               |  |  |  |  |  |
| 4    | CBC5 |       | Trip-zone 5 (TZ5) Select                                           |  |  |  |  |  |
|      |      | 0     | Disable TZ5 as a CBC trip source for this ePWM module              |  |  |  |  |  |
|      |      | 1     | Enable TZ5 as a CBC trip source for this ePWM module               |  |  |  |  |  |
| 3    | CBC4 |       | Trip-zone 4 (TZ4) Select                                           |  |  |  |  |  |
|      |      | 0     | Disable $\overline{TZ4}$ as a CBC trip source for this ePWM module |  |  |  |  |  |
|      |      | 1     | Enable TZ4 as a CBC trip source for this ePWM module               |  |  |  |  |  |
| 2    | CBC3 |       | Trip-zone 3 (TZ3) Select                                           |  |  |  |  |  |
|      |      | 0     | Disable $\overline{TZ3}$ as a CBC trip source for this ePWM module |  |  |  |  |  |
|      |      | 1     | Enable TZ3 as a CBC trip source for this ePWM module               |  |  |  |  |  |
| 1    | CBC2 |       | Trip-zone 2 (TZ2) Select                                           |  |  |  |  |  |
|      |      | 0     | Disable TZ2 as a CBC trip source for this ePWM module              |  |  |  |  |  |
|      |      | 1     | Enable TZ2 as a CBC trip source for this ePWM module               |  |  |  |  |  |
| 0    | CBC1 |       | Trip-zone 1 (TZ1) Select                                           |  |  |  |  |  |
|      |      | 0     | Disable TZ1 as a CBC trip source for this ePWM module              |  |  |  |  |  |
|      |      | 1     | Enable TZ1 as a CBC trip source for this ePWM module               |  |  |  |  |  |

## Table 3-39. Trip-Zone Submodule Select Register (TZSEL) Field Descriptions (continued)

# Figure 3-88. Trip-Zone Control Register (TZCTL)

|                | 12              | 11                             | 10                                                                                                       | 9                                                                                                                       | 8                                                                                                                                                                        |    |    |
|----------------|-----------------|--------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|
| Reserved       |                 |                                |                                                                                                          | DCBE                                                                                                                    | EVT1                                                                                                                                                                     |    |    |
| R-0            |                 |                                | V-0                                                                                                      | R/W-0                                                                                                                   |                                                                                                                                                                          |    |    |
| 5              | 4               | 3                              | 2                                                                                                        | 1                                                                                                                       | 0                                                                                                                                                                        |    |    |
| DCAEVT2 DCAEVT |                 | DCAEVT2 DCAEVT1                |                                                                                                          | TZ                                                                                                                      | ZB                                                                                                                                                                       | TZ | ZA |
| R/W-0 R/W-0    |                 |                                | V-0                                                                                                      | R/V                                                                                                                     | V-0                                                                                                                                                                      |    |    |
|                | R-0<br>5<br>DCA | R-0<br>5 4<br>DCAEVT1<br>R/W-0 | R-0         R/V           5         4         3           DCAEVT1         Tz           R/W-0         R/V | R-0         R/W-0           5         4         3         2           DCAEVT1         TZB           R/W-0         R/W-0 | R-0         R/W-0         R/W-0           5         4         3         2         1           DCAEVT1         TZB         TZ           R/W-0         R/W-0         R/W-0 |    |    |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-40. Trip-Zone Control Register Field Descriptions

| Bit   | Field    | Value | Description                                        |
|-------|----------|-------|----------------------------------------------------|
| 15-12 | Reserved |       | Reserved                                           |
| 11-10 | DCBEVT2  |       | Digital Compare Output B Event 2 Action On EPWMxB: |
|       |          | 00    | High-impedance (EPWMxB = High-impedance state)     |
|       |          | 01    | Force EPWMxB to a high state.                      |
|       |          | 10    | Force EPWMxB to a low state.                       |
|       |          | 11    | Do Nothing, trip action is disabled                |
| 9-8   | DCBEVT1  |       | Digital Compare Output B Event 1 Action On EPWMxB: |
|       |          | 00    | High-impedance (EPWMxB = High-impedance state)     |
|       |          | 01    | Force EPWMxB to a high state.                      |
|       |          | 10    | Force EPWMxB to a low state.                       |
|       |          | 11    | Do Nothing, trip action is disabled                |
| 7-6   | DCAEVT2  |       | Digital Compare Output A Event 2 Action On EPWMxA: |
|       |          | 00    | High-impedance (EPWMxA = High-impedance state)     |
|       |          | 01    | Force EPWMxA to a high state.                      |
|       |          | 10    | Force EPWMxA to a low state.                       |
|       |          | 11    | Do Nothing, trip action is disabled                |



| Bit | Field   | Value | Description                                                                                                                                        |  |  |  |  |  |
|-----|---------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 5-4 | DCAEVT1 |       | igital Compare Output A Event 1 Action On EPWMxA:                                                                                                  |  |  |  |  |  |
|     |         | 00    | High-impedance (EPWMxA = High-impedance state)                                                                                                     |  |  |  |  |  |
|     |         | 01    | Force EPWMxA to a high state.                                                                                                                      |  |  |  |  |  |
|     |         | 10    | Force EPWMxA to a low state.                                                                                                                       |  |  |  |  |  |
|     |         | 11    | Do Nothing, trip action is disabled                                                                                                                |  |  |  |  |  |
| 3-2 | TZB     |       | When a trip event occurs the following action is taken on output EPWMxB. Which trip-zone pins can cause an event is defined in the TZSEL register. |  |  |  |  |  |
|     |         | 00    | High-impedance (EPWMxB = High-impedance state)                                                                                                     |  |  |  |  |  |
|     |         | 01    | Force EPWMxB to a high state                                                                                                                       |  |  |  |  |  |
|     |         | 10    | Force EPWMxB to a low state                                                                                                                        |  |  |  |  |  |
|     |         | 11    | Do nothing, no action is taken on EPWMxB.                                                                                                          |  |  |  |  |  |
| 1-0 | TZA     |       | When a trip event occurs the following action is taken on output EPWMxA. Which trip-zone pins can cause an event is defined in the TZSEL register. |  |  |  |  |  |
|     |         | 00    | High-impedance (EPWMxA = High-impedance state)                                                                                                     |  |  |  |  |  |
|     |         | 01    | Force EPWMxA to a high state                                                                                                                       |  |  |  |  |  |
|     |         | 10    | Force EPWMxA to a low state                                                                                                                        |  |  |  |  |  |
|     |         | 11    | Do nothing, no action is taken on EPWMxA.                                                                                                          |  |  |  |  |  |

# Table 3-40. Trip-Zone Control Register Field Descriptions (continued)

# Figure 3-89. Trip-Zone Enable Interrupt Register (TZEINT)

| 15       |         |              |         |         |       |       | 8        |  |  |  |  |
|----------|---------|--------------|---------|---------|-------|-------|----------|--|--|--|--|
| Reserved |         |              |         |         |       |       |          |  |  |  |  |
| R -0     |         |              |         |         |       |       |          |  |  |  |  |
| 7        | 6       | 5            | 4       | 3       | 2     | 1     | 0        |  |  |  |  |
| Reserved | DCBEVT2 | DCBEVT1      | DCAEVT2 | DCAEVT1 | OST   | CBC   | Reserved |  |  |  |  |
| R-0      | R/W-0   | R/W-0        | R/W-0   | R/W-0   | R/W-0 | R/W-0 | R-0      |  |  |  |  |
|          |         | <b>-</b> · · |         |         |       |       |          |  |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-41. Trip-Zone Enable Interrupt Register (TZEINT) Field Descriptions

| Bits | Name     | Value | Description                                                                                |
|------|----------|-------|--------------------------------------------------------------------------------------------|
| 15-3 | Reserved |       | Reserved                                                                                   |
| 6    | DCBEVT2  |       | Digital Comparator Output B Event 2 Interrupt Enable                                       |
|      |          | 0     | Disabled                                                                                   |
|      |          | 1     | Enabled                                                                                    |
| 5    | DCBEVT1  |       | Digital Comparator Output B Event 1 Interrupt Enable                                       |
|      |          | 0     | Disabled                                                                                   |
|      |          | 1     | Enabled                                                                                    |
| 4    | DCAEVT2  |       | Digital Comparator Output A Event 2 Interrupt Enable                                       |
|      |          | 0     | Disabled                                                                                   |
|      |          | 1     | Enabled                                                                                    |
| 3    | DCAEVT1  |       | Digital Comparator Output A Event 1 Interrupt Enable                                       |
|      |          | 0     | Disabled                                                                                   |
|      |          | 1     | Enabled                                                                                    |
| 2    | OST      |       | Trip-zone One-Shot Interrupt Enable                                                        |
|      |          | 0     | Disable one-shot interrupt generation                                                      |
|      |          | 1     | Enable Interrupt generation; a one-shot trip event will cause a EPWMx_TZINT PIE interrupt. |
| 1    | CBC      |       | Trip-zone Cycle-by-Cycle Interrupt Enable                                                  |
|      |          | 0     | Disable cycle-by-cycle interrupt generation.                                               |

| Bits | Name     | Value | Description                                                                                       |  |  |  |  |  |  |  |
|------|----------|-------|---------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|      |          | 1     | Enable interrupt generation; a cycle-by-cycle trip event will cause an EPWMx_TZINT PIE interrupt. |  |  |  |  |  |  |  |
| 0    | Reserved |       | Reserved                                                                                          |  |  |  |  |  |  |  |

# Table 3-41. Trip-Zone Enable Interrupt Register (TZEINT) Field Descriptions (continued)

# Figure 3-90. Trip-Zone Flag Register (TZFLG)

| 15       |                |               |         |         |     |     | 8   |  |  |  |  |
|----------|----------------|---------------|---------|---------|-----|-----|-----|--|--|--|--|
| Reserved |                |               |         |         |     |     |     |  |  |  |  |
| R-0      |                |               |         |         |     |     |     |  |  |  |  |
| 7        | 6              | 5             | 4       | 3       | 2   | 1   | 0   |  |  |  |  |
| Reserved | DCBEVT2        | DCBEVT1       | DCAEVT2 | DCAEVT1 | OST | CBC | INT |  |  |  |  |
| R-0      | R-0            | R-0           | R-0     | R-0     | R-0 | R-0 | R-0 |  |  |  |  |
|          | Decel/Milter D | Deed asky a v |         |         |     |     |     |  |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-42. Trip-Zone Flag Register Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:7 | Reserved |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6    | DCBEVT2  |       | Latched Status Flag for Digital Compare Output B Event 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|      |          | 0     | Indicates no trip event has occurred on DCBEVT2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |          | 1     | Indicates a trip event has occurred for the event defined for DCBEVT2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5    | DCBEVT1  |       | Latched Status Flag for Digital Compare Output B Event 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|      |          | 0     | Indicates no trip event has occurred on DCBEVT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |          | 1     | Indicates a trip event has occurred for the event defined for DCBEVT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4    | DCAEVT2  |       | Latched Status Flag for Digital Compare Output A Event 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|      |          | 0     | Indicates no trip event has occurred on DCAEVT2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |          | 1     | Indicates a trip event has occurred for the event defined for DCAEVT2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3    | DCAEVT1  |       | Latched Status Flag for Digital Compare Output A Event 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|      |          | 0     | Indicates no trip event has occurred on DCAEVT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |          | 1     | Indicates a trip event has occurred for the event defined for DCAEVT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2    | OST      |       | Latched Status Flag for A One-Shot Trip Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |          | 0     | No one-shot trip event has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|      |          | 1     | Indicates a trip event has occurred on a pin selected as a one-shot trip source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|      |          |       | This bit is cleared by writing the appropriate value to the TZCLR register .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1    | CBC      |       | Latched Status Flag for Cycle-By-Cycle Trip Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      |          | 0     | No cycle-by-cycle trip event has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      |          | 1     | Indicates a trip event has occurred on a signal selected as a cycle-by-cycle trip source. The TZFLG[CBC] bit will remain set until it is manually cleared by the user. If the cycle-by-cycle trip event is still present when the CBC bit is cleared, then CBC will be immediately set again. The specified condition on the signal is automatically cleared when the ePWM time-base counter reaches zero (TBCTR = 0x0000) if the trip condition is no longer present. The condition on the signal is only cleared when the TBCTR = 0x0000 no matter where in the cycle the CBC flag is cleared. |
|      |          |       | This bit is cleared by writing the appropriate value to the TZCLR register .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0    | INT      |       | Latched Trip Interrupt Status Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |          | 0     | Indicates no interrupt has been generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      |          | 1     | Indicates an EPWMx_TZINT PIE interrupt was generated because of a trip condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      |          |       | No further EPWMx_TZINT PIE interrupts will be generated until this flag is cleared. If the interrupt flag is cleared when either CBC or OST is set, then another interrupt pulse will be generated. Clearing all flag bits will prevent further interrupts.                                                                                                                                                                                                                                                                                                                                      |
|      |          |       | This bit is cleared by writing the appropriate value to the TZCLR register .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



Registers

| Figure 3-91. Trip-Zone Clear Register (TZCLR) |                                                |         |         |         |       |       |       |  |  |  |  |  |
|-----------------------------------------------|------------------------------------------------|---------|---------|---------|-------|-------|-------|--|--|--|--|--|
| 15                                            |                                                |         |         |         |       |       | 8     |  |  |  |  |  |
|                                               | Reserved                                       |         |         |         |       |       |       |  |  |  |  |  |
|                                               | R-0                                            |         |         |         |       |       |       |  |  |  |  |  |
| 7                                             | 6                                              | 5       | 4       | 3       | 2     | 1     | 0     |  |  |  |  |  |
| Reserved                                      | served DCBEVT2 DCBEVT1 DCAEVT2 DCAEVT1 OST CBC |         |         |         |       |       |       |  |  |  |  |  |
| R-0                                           | R/W1C-0                                        | R/W1C-0 | R/W1C-0 | R/W1C-0 | R/W-0 | R/W-0 | R/W-0 |  |  |  |  |  |

LEGEND: R/W = Read/Write; nC - write n to clear; R = Read only; -n = value after reset

| Bit  | Field    | Value                                           | Description                                                                                                                                                                                                                                                                      |
|------|----------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-7 | Reserved |                                                 | Reserved                                                                                                                                                                                                                                                                         |
| 6    | DCBEVT2  | Clear Flag for Digital Compare Output B Event 2 |                                                                                                                                                                                                                                                                                  |
|      |          | 0                                               | Writing 0 has no effect. This bit always reads back 0.                                                                                                                                                                                                                           |
|      |          | 1                                               | Writing 1 clears the DCBEVT2 event trip condition.                                                                                                                                                                                                                               |
| 5    | DCBEVT1  |                                                 | Clear Flag for Digital Compare Output B Event 1                                                                                                                                                                                                                                  |
|      |          | 0                                               | Writing 0 has no effect. This bit always reads back 0.                                                                                                                                                                                                                           |
|      |          | 1                                               | Writing 1 clears the DCBEVT1 event trip condition.                                                                                                                                                                                                                               |
| 4    | DCAEVT2  |                                                 | Clear Flag for Digital Compare Output A Event 2                                                                                                                                                                                                                                  |
|      |          | 0                                               | Writing 0 has no effect. This bit always reads back 0.                                                                                                                                                                                                                           |
|      |          | 1                                               | Writing 1 clears the DCAEVT2 event trip condition.                                                                                                                                                                                                                               |
| 3    | DCAEVT1  |                                                 | Clear Flag for Digital Compare Output A Event 1                                                                                                                                                                                                                                  |
|      |          | 0                                               | Writing 0 has no effect. This bit always reads back 0.                                                                                                                                                                                                                           |
|      |          | 1                                               | Writing 1 clears the DCAEVT1 event trip condition.                                                                                                                                                                                                                               |
| 2    | OST      |                                                 | Clear Flag for One-Shot Trip (OST) Latch                                                                                                                                                                                                                                         |
|      |          | 0                                               | Has no effect. Always reads back a 0.                                                                                                                                                                                                                                            |
|      |          | 1                                               | Clears this Trip (set) condition.                                                                                                                                                                                                                                                |
| 1    | CBC      |                                                 | Clear Flag for Cycle-By-Cycle (CBC) Trip Latch                                                                                                                                                                                                                                   |
|      |          | 0                                               | Has no effect. Always reads back a 0.                                                                                                                                                                                                                                            |
|      |          | 1                                               | Clears this Trip (set) condition.                                                                                                                                                                                                                                                |
| 0    | INT      |                                                 | Global Interrupt Clear Flag                                                                                                                                                                                                                                                      |
|      |          | 0                                               | Has no effect. Always reads back a 0.                                                                                                                                                                                                                                            |
|      |          | 1                                               | Clears the trip-interrupt flag for this ePWM module (TZFLG[INT]).                                                                                                                                                                                                                |
|      |          |                                                 | <b>NOTE:</b> No further EPWMx_TZINT PIE interrupts will be generated until the flag is cleared. If the TZFLG[INT] bit is cleared and any of the other flag bits are set, then another interrupt pulse will be generated. Clearing all flag bits will prevent further interrupts. |

## Table 3-43. Trip-Zone Clear Register (TZCLR) Field Descriptions

#### Figure 3-92. Trip-Zone Force Register (TZFRC)

| 15       |                   |                  |                  |         |       |       | 8        |  |  |  |  |
|----------|-------------------|------------------|------------------|---------|-------|-------|----------|--|--|--|--|
| Reserved |                   |                  |                  |         |       |       |          |  |  |  |  |
| R-0      |                   |                  |                  |         |       |       |          |  |  |  |  |
| 7        | 6                 | 5                | 4                | 3       | 2     | 1     | 0        |  |  |  |  |
| Reserved | DCBEVT2           | DCBEVT1          | DCAEVT2          | DCAEVT1 | OST   | CBC   | Reserved |  |  |  |  |
| R-0      | R/W-0             | R/W-0            | R/W-0            | R/W-0   | R/W-0 | R/W-0 | R- 0     |  |  |  |  |
|          | - Dood/Mrito: D - | Pood only: n - v | alua aftar racat |         |       |       |          |  |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-44. Trip-Zone Force Register (TZFRC) Field Descriptions

| Bits | Name     | Value | Description                                     |
|------|----------|-------|-------------------------------------------------|
| 15-7 | Reserved |       | Reserved                                        |
| 6    | DCBEVT2  |       | Force Flag for Digital Compare Output B Event 2 |

| Bits | Name     | Value | Description                                                                        |
|------|----------|-------|------------------------------------------------------------------------------------|
|      |          | 0     | Writing 0 has no effect. This bit always reads back 0.                             |
|      |          | 1     | Writing 1 forces the DCBEVT2 event trip condition and sets the TZFLG[DCBEVT2] bit. |
| 5    | DCBEVT1  |       | Force Flag for Digital Compare Output B Event 1                                    |
|      |          | 0     | Writing 0 has no effect. This bit always reads back 0.                             |
|      |          | 1     | Writing 1 forces the DCBEVT1 event trip condition and sets the TZFLG[DCBEVT1] bit. |
| 4    | DCAEVT2  |       | Force Flag for Digital Compare Output A Event 2                                    |
|      |          | 0     | Writing 0 has no effect. This bit always reads back 0.                             |
|      |          | 1     | Writing 1 forces the DCAEVT2 event trip condition and sets the TZFLG[DCAEVT2] bit. |
| 3    | DCAEVT1  |       | Force Flag for Digital Compare Output A Event 1                                    |
|      |          | 0     | Writing 0 has no effect. This bit always reads back 0                              |
|      |          | 1     | Writing 1 forces the DCAEVT1 event trip condition and sets the TZFLG[DCAEVT1] bit. |
| 2    | OST      |       | Force a One-Shot Trip Event via Software                                           |
|      |          | 0     | Writing of 0 is ignored. Always reads back a 0.                                    |
|      |          | 1     | Forces a one-shot trip event and sets the TZFLG[OST] bit.                          |
| 1    | CBC      |       | Force a Cycle-by-Cycle Trip Event via Software                                     |
|      |          | 0     | Writing of 0 is ignored. Always reads back a 0.                                    |
|      |          | 1     | Forces a cycle-by-cycle trip event and sets the TZFLG[CBC] bit.                    |
| 0    | Reserved |       | Reserved                                                                           |

#### Table 3-44. Trip-Zone Force Register (TZFRC) Field Descriptions (continued)

# Figure 3-93. Trip Zone Digital Compare Event Select Register (TZDCSEL)

| 15       | 12 | 11   | 9   | 8   | 6     | 5   | 3    | 2   | 0     |  |  |  |
|----------|----|------|-----|-----|-------|-----|------|-----|-------|--|--|--|
| Reserved |    | DCBE | VT2 | DCE | BEVT1 | DCA | EVT2 | DCA | AEVT1 |  |  |  |
| R-0      |    | R/W  | /-0 | R/  | /W-0  | R/V | V-0  | R   | /W-0  |  |  |  |
|          |    |      |     |     |       |     |      |     |       |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-45. Trip Zone Digital Compare Event Select Register (TZDCSEL) Field Descriptions

| Bit   | Field    | Value | Description                                |  |  |  |
|-------|----------|-------|--------------------------------------------|--|--|--|
| 15-12 | Reserved |       | Reserved                                   |  |  |  |
| 11-9  | DCBEVT2  |       | Digital Compare Output B Event 2 Selection |  |  |  |
|       |          | 000   | Event disabled                             |  |  |  |
|       |          | 001   | DCBH = low, DCBL = don't care              |  |  |  |
|       |          | 010   | DCBH = high, DCBL = don't care             |  |  |  |
|       |          | 011   | DCBL = low, DCBH = don't care              |  |  |  |
|       |          | 100   | DCBL = high, DCBH = don't care             |  |  |  |
|       |          | 101   | DCBL = high, DCBH = low                    |  |  |  |
|       |          | 110   | reserved                                   |  |  |  |
|       |          | 111   | reserved                                   |  |  |  |
| 8-6   | DCBEVT1  |       | Digital Compare Output B Event 1 Selection |  |  |  |
|       |          | 000   | Event disabled                             |  |  |  |
|       |          | 001   | DCBH = low, DCBL = don't care              |  |  |  |
|       |          | 010   | DCBH = high, DCBL = don't care             |  |  |  |
|       |          | 011   | DCBL = low, DCBH = don't care              |  |  |  |
|       |          | 100   | DCBL = high, DCBH = don't care             |  |  |  |
|       |          | 101   | DCBL = high, DCBH = low                    |  |  |  |
|       |          | 110   | reserved                                   |  |  |  |
|       |          | 111   | reserved                                   |  |  |  |

|     | •       | •     |                                            |
|-----|---------|-------|--------------------------------------------|
| Bit | Field   | Value | Description                                |
| 5-3 | DCAEVT2 |       | Digital Compare Output A Event 2 Selection |
|     |         | 000   | Event disabled                             |
|     |         | 001   | DCAH = low, DCAL = don't care              |
|     |         | 010   | DCAH = high, DCAL = don't care             |
|     |         | 011   | DCAL = low, DCAH = don't care              |
|     |         | 100   | DCAL = high, DCAH = don't care             |
|     |         | 101   | DCAL = high, DCAH = low                    |
|     |         | 110   | reserved                                   |
|     |         | 111   | reserved                                   |
| 2-0 | DCAEVT1 |       | Digital Compare Output A Event 1 Selection |
|     |         | 000   | Event disabled                             |
|     |         | 001   | DCAH = low, DCAL = don't care              |
|     |         | 010   | DCAH = high, DCAL = don't care             |
|     |         | 011   | DCAL = low, DCAH = don't care              |
|     |         | 100   | DCAL = high, DCAH = don't care             |
|     |         | 101   | DCAL = high, DCAH = low                    |
|     |         | 110   | reserved                                   |
|     |         | 1     |                                            |

# Table 3-45. Trip Zone Digital Compare Event Select Register (TZDCSEL) Field Descriptions (continued)

111

reserved

Registers

#### Registers

# 3.4.7 Digital Compare Submodule Registers

| Figure 3-94. Digital Compare Trip Select (DCTRIPSEL) |             |    |    |             |   |
|------------------------------------------------------|-------------|----|----|-------------|---|
| 15                                                   |             | 12 | 11 |             | 8 |
|                                                      | DCBLCOMPSEL |    |    | DCBHCOMPSEL |   |
|                                                      | R/W-0       |    |    | R/W-0       |   |
| 7                                                    |             | 4  | 3  |             | 0 |
|                                                      | DCALCOMPSEL |    |    | DCAHCOMPSEL |   |
|                                                      | R/W-0       |    |    | R/W-0       |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-46. Digital Compare Trip Select (DCTRIPSEL) Field Descriptions

| Bit   | Field       | Value | Description                                                                                                                                                     |
|-------|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | DCBLCOMPSEL |       | Digital Compare B Low Input Select                                                                                                                              |
|       |             |       | Defines the source for the DCBL input. The TZ signals, when used as trip signals, are treated as normal inputs and can be defined as active high or active low. |
|       |             | 0000  | TZ1 input                                                                                                                                                       |
|       |             | 0001  | TZ2 input                                                                                                                                                       |
|       |             | 0010  | TZ3 input                                                                                                                                                       |
|       |             | 1000  | CTRIPM1 input                                                                                                                                                   |
|       |             | 1001  | CTRIPM2 input                                                                                                                                                   |
|       |             | 1010  | CTRIPPFC input                                                                                                                                                  |
|       |             |       | Values not shown are reserved. If a device does not have a particular comparitor, then that option is reserved.                                                 |
| 11-8  | DCBHCOMPSEL |       | Digital Compare B High Input Select                                                                                                                             |
|       |             |       | Defines the source for the DCBH input. The TZ signals, when used as trip signals, are treated as normal inputs and can be defined as active high or active low. |
|       |             | 0000  | TZ1 input                                                                                                                                                       |
|       |             | 0001  | TZ2 input                                                                                                                                                       |
|       |             | 0010  | TZ3 input                                                                                                                                                       |
|       |             | 1000  | CTRIPM1 input                                                                                                                                                   |
|       |             | 1001  | CTRIPM2 input                                                                                                                                                   |
|       |             | 1010  | CTRIPPFC input                                                                                                                                                  |
|       |             |       | Values not shown are reserved. If a device does not have a particular comparitor, then that option is reserved.                                                 |
| 7-4   | DCALCOMPSEL |       | Digital Compare A Low Input Select                                                                                                                              |
|       |             |       | Defines the source for the DCAL input. The TZ signals, when used as trip signals, are treated as normal inputs and can be defined as active high or active low. |
|       |             | 0000  | TZ1 input                                                                                                                                                       |
|       |             | 0001  | TZ2 input                                                                                                                                                       |
|       |             | 0010  | TZ3 input                                                                                                                                                       |
|       |             | 1000  | CTRIPM1 input                                                                                                                                                   |
|       |             | 1001  | CTRIPM2 input                                                                                                                                                   |
|       |             | 1010  | CTRIPPFC input                                                                                                                                                  |
|       |             |       | Values not shown are reserved. If a device does not have a particular comparitor, then that option is reserved.                                                 |

## Table 3-46. Digital Compare Trip Select (DCTRIPSEL) Field Descriptions (continued)

| Bit | Field       | Value | Description                                                                                                                                                     |
|-----|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3-0 | DCAHCOMPSEL |       | Digital Compare A High Input Select                                                                                                                             |
|     |             |       | Defines the source for the DCAH input. The TZ signals, when used as trip signals, are treated as normal inputs and can be defined as active high or active low. |
|     |             | 0000  | TZ1 input                                                                                                                                                       |
|     |             | 0001  | TZ2 input                                                                                                                                                       |
|     |             | 0010  | TZ3 input                                                                                                                                                       |
|     |             | 1000  | CTRIPM1 input                                                                                                                                                   |
|     |             | 1001  | CTRIPM2 input                                                                                                                                                   |
|     |             | 1010  | CTRIPPFC input                                                                                                                                                  |
|     |             |       | Values not shown are reserved. If a device does not have a particular comparitor, then that option is reserved.                                                 |

# Figure 3-95. Digital Compare A Control Register (DCACTL)

| 15 |          |   |           | 10       | 9                  | 8          |
|----|----------|---|-----------|----------|--------------------|------------|
|    | Reserved |   |           |          | EVT2FRC<br>SYNCSEL | EVT2SRCSEL |
|    | R-0      |   |           |          | R/W-0              | R/W-0      |
| 7  |          | 4 | 3         | 2        | 1                  | 0          |
| Re | served   |   | EVT1SYNCE | EVT1SOCE | EVT1FRC<br>SYNCSEL | EVT1SRCSEL |
|    | R-0      |   | R/W-0     | R/W-0    | R/W-0              | R/W-0      |
|    |          |   |           |          |                    |            |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-47. Digital Compare A Control Register (DCACTL) Field Descriptions

| Bit   | Field      | Value | Description                                 |  |
|-------|------------|-------|---------------------------------------------|--|
| 15-10 | Reserved   |       | Reserved                                    |  |
| 9     | EVT2FRC    |       | DCAEVT2 Force Synchronization Signal Select |  |
|       | SYNCSEL    | 0     | Source Is Synchronous Signal                |  |
|       |            | 1     | Source Is Asynchronous Signal               |  |
| 8     | EVT2SRCSEL |       | DCAEVT2 Source Signal Select                |  |
|       |            | 0     | Source Is DCAEVT2 Signal                    |  |
|       |            | 1     | Source Is DCEVTFILT Signal                  |  |
| 7-4   | Reserved   |       | Reserved                                    |  |
| 3     | EVT1SYNCE  |       | DCAEVT1 SYNC, Enable/Disable                |  |
|       |            | 0     | SYNC Generation Disabled                    |  |
|       |            | 1     | SYNC Generation Enabled                     |  |
| 2     | EVT1SOCE   |       | DCAEVT1 SOC, Enable/Disable                 |  |
|       |            | 0     | SOC Generation Disabled                     |  |
|       |            | 1     | SOC Generation Enabled                      |  |
| 1     | EVT1FRC    |       | DCAEVT1 Force Synchronization Signal Select |  |
|       | SYNCSEL    | 0     | Source Is Synchronous Signal                |  |
|       |            | 1     | Source Is Asynchronous Signal               |  |
| 0     | EVT1SRCSEL |       | DCAEVT1 Source Signal Select                |  |
|       |            | 0     | Source Is DCAEVT1 Signal                    |  |
|       |            | 1     | Source Is DCEVTFILT Signal                  |  |



|    | Figure 3-96. Di | gital Com | pare B Control | Register (DCI | BCTL)              |            |
|----|-----------------|-----------|----------------|---------------|--------------------|------------|
| 15 |                 |           |                | 10            | 9                  | 8          |
|    | Reserv          | red       |                |               | EVT2FRC<br>SYNCSEL | EVT2SRCSEL |
|    | R-0             |           |                |               | R/W-0              | R/W-0      |
| 7  |                 | 4         | 3              | 2             | 1                  | 0          |
|    | Reserved        |           | EVT1SYNCE      | EVT1SOCE      | EVT1FRC<br>SYNCSEL | EVT1SRCSEL |
|    | R-0             |           | R/W-0          | R/W-0         | R/W-0              | R/W-0      |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

Registers

# Table 3-48. Digital Compare B Control Register (DCBCTL) Field Descriptions

| Bit   | Field      | Value | Description                                 |  |  |
|-------|------------|-------|---------------------------------------------|--|--|
| 15-10 | Reserved   |       | Reserved                                    |  |  |
| 9     | EVT2FRC    |       | DCBEVT2 Force Synchronization Signal Select |  |  |
|       | SYNCSEL    | 0     | Source Is Synchronous Signal                |  |  |
|       |            | 1     | Source Is Asynchronous Signal               |  |  |
| 8     | EVT2SRCSEL |       | DCBEVT2 Source Signal Select                |  |  |
|       |            | 0     | Source Is DCBEVT2 Signal                    |  |  |
|       |            | 1     | Source Is DCEVTFILT Signal                  |  |  |
| 7-4   | Reserved   |       | Reserved                                    |  |  |
| 3     | EVT1SYNCE  |       | DCBEVT1 SYNC, Enable/Disable                |  |  |
|       |            | 0     | SYNC Generation Disabled                    |  |  |
|       |            | 1     | SYNC Generation Enabled                     |  |  |
| 2     | EVT1SOCE   |       | DCBEVT1 SOC, Enable/Disable                 |  |  |
|       |            | 0     | SOC Generation Disabled                     |  |  |
|       |            | 1     | SOC Generation Enabled                      |  |  |
| 1     | EVT1FRC    |       | DCBEVT1 Force Synchronization Signal Select |  |  |
|       | SYNCSEL    | 0     | Source Is Synchronous Signal                |  |  |
|       |            | 1     | Source Is Asynchronous Signal               |  |  |
| 0     | EVT1SRCSEL |       | DCBEVT1 Source Signal Select                |  |  |
|       |            | 0     | Source Is DCBEVT1 Signal                    |  |  |
|       |            | 1     | Source Is DCEVTFILT Signal                  |  |  |

#### Figure 3-97. Digital Compare Filter Control Register (DCFCTL)

| 15       |          | 13       | 12  |          |          |     | 8    |
|----------|----------|----------|-----|----------|----------|-----|------|
|          | Reserved |          |     |          | Reserved |     |      |
| R-0      |          |          |     |          | R-0      |     |      |
| 7        | 6        | 5        | 4   | 3        | 2        | 1   | 0    |
| Reserved | Reserved | PULSESEL |     | BLANKINV | BLANKE   | SRO | CSEL |
| R-0      | R-0      | R/M      | /-0 | R/W-0    | R/W-0    | R/  | W-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-49. Digital Compare Filter Control Register (DCFCTL) Field Descriptions

| Bit   | Field    | Value | Description          |
|-------|----------|-------|----------------------|
| 15-13 | Reserved |       | Reserved             |
| 12-8  | Reserved |       | Reserved for TI Test |
| 7     | Reserved |       | Reserved             |
| 6     | Reserved |       | Reserved for TI Test |

# Table 3-49. Digital Compare Filter Control Register (DCFCTL) Field Descriptions (continued)

| Bit | Field    | Value | Description                                       |
|-----|----------|-------|---------------------------------------------------|
| 5-4 | PULSESEL |       | Pulse Select For Blanking & Capture Alignment     |
|     |          | 00    | Time-base counter equal to period (TBCTR = TBPRD) |
|     |          | 01    | Time-base counter equal to zero (TBCTR = 0x0000)  |
|     |          | 10    | Reserved                                          |
|     |          | 11    | Reserved                                          |
| 3   | BLANKINV |       | Blanking Window Inversion                         |
|     |          | 0     | Blanking window not inverted                      |
|     |          | 1     | Blanking window inverted                          |
| 2   | BLANKE   |       | Blanking Window Enable/Disable                    |
|     |          | 0     | Blanking window is disabled                       |
|     |          | 1     | Blanking window is enabled                        |
| 1-0 | SRCSEL   |       | Filter Block Signal Source Select                 |
|     |          | 00    | Source Is DCAEVT1 Signal                          |
|     |          | 01    | Source Is DCAEVT2 Signal                          |
|     |          | 10    | Source Is DCBEVT1 Signal                          |
|     |          | 11    | Source Is DCBEVT2 Signal                          |

#### Figure 3-98. Digital Compare Capture Control Register (DCCAPCTL)

| 15 |          |   |          | 8     |
|----|----------|---|----------|-------|
|    | Reserved |   |          |       |
|    | R-0      |   |          |       |
| 7  |          | 2 | 1        | 0     |
|    | Reserved |   | SHDWMODE | CAPE  |
|    | R-0      |   | R/W-0    | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 3-50. Digital Compare Capture Control Register (DCCAPCTL) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                                                                           |
|------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-2 | Reserved |       | Reserved                                                                                                                                                                                                                              |
| 1    | SHDWMODE |       | TBCTR Counter Capture Shadow Select Mode                                                                                                                                                                                              |
|      |          | 0     | Enable shadow mode. The DCCAP active register is copied to shadow register on a TBCTR = TBPRD or TBCTR = zero event as defined by the DCFCTL[PULSESEL] bit. CPU reads of the DCCAP register will return the shadow register contents. |
|      |          | 1     | Active Mode. In this mode the shadow register is disabled. CPU reads from the DCCAP register will always return the active register contents.                                                                                         |
| 0    | CAPE     |       | TBCTR Counter Capture Enable/Disable                                                                                                                                                                                                  |
|      |          | 0     | Disable the time-base counter capture.                                                                                                                                                                                                |
|      |          | 1     | Enable the time-base counter capture.                                                                                                                                                                                                 |

# Figure 3-99. Digital Compare Counter Capture Register (DCCAP)

| 15 | 0     | ) |
|----|-------|---|
|    | DCCAP |   |
|    | R-0   |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

TEXAS INSTRUMENTS

www.ti.com

# Table 3-51. Digital Compare Counter Capture Register (DCCAP) Field Descriptions

| Bit  | Field | Value      | Description                                                                                                                                                                                                                                                                                          |
|------|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | DCCAP | 0000-FFFFh | Digital Compare Time-Base Counter Capture                                                                                                                                                                                                                                                            |
|      |       |            | To enable time-base counter capture, set the DCCAPCLT[CAPE] bit to 1.                                                                                                                                                                                                                                |
|      |       |            | If enabled, reflects the value of the time-base counter (TBCTR) on the low to high edge transition of a filtered (DCEVTFLT) event. Further capture events are ignored until the next period or zero as selected by the DCFCTL[PULSESEL] bit.                                                         |
|      |       |            | Shadowing of DCCAP is enabled and disabled by the DCCAPCTL[SHDWMODE] bit. By default this register is shadowed.                                                                                                                                                                                      |
|      |       |            | <ul> <li>If DCCAPCTL[SHDWMODE] = 0, then the shadow is enabled. In this mode, the active register<br/>is copied to the shadow register on the TBCTR = TBPRD or TBCTR = zero as defined by the<br/>DCFCTL[PULSESEL] bit. CPU reads of this register will return the shadow register value.</li> </ul> |
|      |       |            | <ul> <li>If DCCAPCTL[SHDWMODE] = 1, then the shadow register is disabled. In this mode, CPU<br/>reads will return the active register value.</li> </ul>                                                                                                                                              |
|      |       |            | The active and shadow registers share the same memory map address.                                                                                                                                                                                                                                   |

# Figure 3-100. Digital Compare Filter Offset Register (DCFOFFSET)

| 15 |          | 0 |
|----|----------|---|
|    | DCOFFSET |   |
|    |          |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 3-52. Digital Compare Filter Offset Register (DCFOFFSET) Field Descriptions

| Bit  | Field  | Value       | Description                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | OFFSET | 0000- FFFFh | Blanking Window Offset                                                                                                                                                                                                                                                                                                                                                          |
|      |        |             | These 16-bits specify the number of TBCLK cycles from the blanking window reference to the point when the blanking window is applied. The blanking window reference is either period or zero as defined by the DCFCTL[PULSESEL] bit.                                                                                                                                            |
|      |        |             | This offset register is shadowed and the active register is loaded at the reference point defined by DCFCTL[PULSESEL]. The offset counter is also initialized and begins to count down when the active register is loaded. When the counter expires, the blanking window is applied. If the blanking window is currently active, then the blanking window counter is restarted. |

#### Figure 3-101. Digital Compare Filter Offset Counter Register (DCFOFFSETCNT)

| 15 |           | 0 |
|----|-----------|---|
|    | OFFSETCNT |   |
|    | R-0       |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-53. Digital Compare Filter Offset Counter Register (DCFOFFSETCNT) Field Descriptions

| Bit  | Field     | Value       | Description                                                                                                                                                                                                                     |
|------|-----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | OFFSETCNT | 0000- FFFFh | Blanking Offset Counter                                                                                                                                                                                                         |
|      |           |             | These 16-bits are read only and indicate the current value of the offset counter. The counter counts down to zero and then stops until it is re-loaded on the next period or zero event as defined by the DCFCTL[PULSESEL] bit. |
|      |           |             | The offset counter is not affected by the free/soft emulation bits. That is, it will always continue to count down if the device is halted by a emulation stop.                                                                 |



Registers

| Figure 3-102. Digital Compare Filter Window Register (DCFWINDOW) |          |   |  |
|------------------------------------------------------------------|----------|---|--|
| 15                                                               |          | 8 |  |
|                                                                  | Reserved |   |  |
|                                                                  | R-0      |   |  |
| 7                                                                |          | 0 |  |
|                                                                  | WINDOW   |   |  |
|                                                                  | R/W-0    |   |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-54. Digital Compare Filter Window Register (DCFWINDOW) Field Descriptions

| Bit  | Field    | Value  | Description                                                                                                                                                                                                                                                                                                           |
|------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved |        | Reserved                                                                                                                                                                                                                                                                                                              |
| 7-0  | WINDOW   |        | Blanking Window Width                                                                                                                                                                                                                                                                                                 |
|      |          | 00h    | No blanking window is generated.                                                                                                                                                                                                                                                                                      |
|      |          | 01-FFh | Specifies the width of the blanking window in TBCLK cycles. The blanking window begins when the offset counter expires. When this occurs, the window counter is loaded and begins to count down. If the blanking window is currently active and the offset counter expires, the blanking window counter is restarted. |
|      |          |        | The blanking window can cross a PWM period boundary.                                                                                                                                                                                                                                                                  |

# Figure 3-103. Digital Compare Filter Window Counter Register (DCFWINDOWCNT)

| 15 |           | 8 |
|----|-----------|---|
|    | Reserved  |   |
|    | R-0       |   |
| 7  |           | 0 |
|    | WINDOWCNT |   |
|    | R-0       |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-55. Digital Compare Filter Window Counter Register (DCFWINDOWCNT) Field Descriptions

| Bit  | Field     | Value | Description                                                                                                                                                                                       |
|------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved  |       | Any writes to these bit(s) must always have a value of 0.                                                                                                                                         |
| 7-0  | WINDOWCNT | 00-FF | Blanking Window Counter                                                                                                                                                                           |
|      |           |       | These 8 bits are read only and indicate the current value of the window counter. The counter counts down to zero and then stops until it is re-loaded when the offset counter reaches zero again. |

# 3.4.8 Event-Trigger Submodule Registers

The event trigger selection register (ETSEL) and field descriptions below describe the registers for the event-trigger submodule.

| Figure 3-104. Event-Trigger Selection Register (ETSEL) |          |    |        |    |         |   |  |  |  |  |
|--------------------------------------------------------|----------|----|--------|----|---------|---|--|--|--|--|
| 15                                                     | 14       | 12 | 11     | 10 |         | 8 |  |  |  |  |
| SOCBEN                                                 | SOCBSEL  |    | SOCAEN |    | SOCASEL |   |  |  |  |  |
| R/W-0                                                  | R/W-0    |    | R/W-0  |    | R/W-0   |   |  |  |  |  |
| 7                                                      |          | 4  | 3      | 2  |         | 0 |  |  |  |  |
|                                                        | Reserved |    | INTEN  |    | INTSEL  |   |  |  |  |  |
|                                                        | R-0      |    | R/W-0  |    | R/W-0   |   |  |  |  |  |

uro 2-104 Event-Trigger Selection Pedister (ETSEL)

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



# Table 3-56. Event-Trigger Selection Register (ETSEL) Field Descriptions

| Bits  | Name     | Value | Description                                                                                                                          |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------|
| 15    | SOCBEN   |       | Enable the ADC Start of Conversion B (EPWMxSOCB) Pulse                                                                               |
|       |          | 0     | Disable EPWMxSOCB.                                                                                                                   |
|       |          | 1     | Enable EPWMxSOCB pulse.                                                                                                              |
| 14-12 | SOCBSEL  |       | EPWMxSOCB Selection Options                                                                                                          |
|       |          |       | These bits determine when a EPWMxSOCB pulse will be generated.                                                                       |
|       |          | 000   | Enable DCBEVT1.soc event                                                                                                             |
|       |          | 001   | Enable event time-base counter equal to zero. (TBCTR = 0x0000)                                                                       |
|       |          | 010   | Enable event time-base counter equal to period (TBCTR = TBPRD)                                                                       |
|       |          | 011   | Enable event time-base counter equal to zero or period (TBCTR = 0x0000 or TBCTR = TBPRD). This mode is useful in up-down count mode. |
|       |          | 100   | Enable event time-base counter equal to CMPA when the timer is incrementing.                                                         |
|       |          | 101   | Enable event time-base counter equal to CMPA when the timer is decrementing.                                                         |
|       |          | 110   | Enable event: time-base counter equal to CMPB when the timer is incrementing.                                                        |
|       |          | 111   | Enable event: time-base counter equal to CMPB when the timer is decrementing.                                                        |
| 11    | SOCAEN   |       | Enable the ADC Start of Conversion A (EPWMxSOCA) Pulse                                                                               |
|       |          | 0     | Disable EPWMxSOCA.                                                                                                                   |
|       |          | 1     | Enable EPWMxSOCA pulse.                                                                                                              |
| 10-8  | SOCASEL  |       | EPWMxSOCA Selection Options                                                                                                          |
|       |          |       | These bits determine when a EPWMxSOCA pulse will be generated.                                                                       |
|       |          | 000   | Enable DCAEVT1.soc event                                                                                                             |
|       |          | 001   | Enable event time-base counter equal to zero. (TBCTR = 0x0000)                                                                       |
|       |          | 010   | Enable event time-base counter equal to period (TBCTR = TBPRD)                                                                       |
|       |          | 011   | Enable event time-base counter equal to zero or period (TBCTR = 0x0000 or TBCTR = TBPRD). This mode is useful in up-down count mode. |
|       |          | 100   | Enable event time-base counter equal to CMPA when the timer is incrementing.                                                         |
|       |          | 101   | Enable event time-base counter equal to CMPA when the timer is decrementing.                                                         |
|       |          | 110   | Enable event: time-base counter equal to CMPB when the timer is incrementing.                                                        |
|       |          | 111   | Enable event: time-base counter equal to CMPB when the timer is decrementing.                                                        |
| 7-4   | Reserved |       | Reserved                                                                                                                             |
| 3     | INTEN    |       | Enable ePWM Interrupt (EPWMx_INT) Generation                                                                                         |
|       |          | 0     | Disable EPWMx_INT generation                                                                                                         |
|       |          | 1     | Enable EPWMx_INT generation                                                                                                          |
| 2-0   | INTSEL   |       | ePWM Interrupt (EPWMx_INT) Selection Options                                                                                         |
|       |          | 000   | Reserved                                                                                                                             |
|       |          | 001   | Enable event time-base counter equal to zero. (TBCTR = 0x0000)                                                                       |
|       |          | 010   | Enable event time-base counter equal to period (TBCTR = TBPRD)                                                                       |
|       |          | 011   | Enable event time-base counter equal to zero or period (TBCTR = 0x0000 or TBCTR = TBPRD). This mode is useful in up-down count mode. |
|       |          | 100   | Enable event time-base counter equal to CMPA when the timer is incrementing.                                                         |
|       |          | 101   | Enable event time-base counter equal to CMPA when the timer is decrementing.                                                         |
|       |          | 110   | Enable event: time-base counter equal to CMPB when the timer is incrementing.                                                        |
|       |          | 111   | Enable event: time-base counter equal to CMPB when the timer is decrementing.                                                        |



Registers

| Figure 3-105. Event-Trigger Prescale Register (ETPS) |          |         |     |         |     |       |     |  |
|------------------------------------------------------|----------|---------|-----|---------|-----|-------|-----|--|
| 15                                                   | 14       | 13      | 12  | 11      | 10  | 9     | 8   |  |
| SOCBCNT SOCBPRD                                      |          | SOCACNT |     | SOCAPRD |     |       |     |  |
| R                                                    | -0       | RΛ      | N-0 | R-0     |     | R/W-0 |     |  |
| 7 4                                                  |          | 4       | 3   | 2       | 1   | 0     |     |  |
|                                                      | Reserved |         |     | INT     | CNT | INT   | PRD |  |
| R-0                                                  |          |         | R   | -0      | R/V | V-0   |     |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-57. Event-Trigger Prescale Register (ETPS) Field Descriptions

| Bits  | Name     |    | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|----------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14 | SOCBCNT  |    | ePWM ADC Start-of-Conversion B Event (EPWMxSOCB) Counter Register                                                                                                                                                                                                                                                                                                                                 |
|       |          |    | These bits indicate how many selected ETSEL[SOCBSEL] events have occurred:                                                                                                                                                                                                                                                                                                                        |
|       |          | 00 | No events have occurred.                                                                                                                                                                                                                                                                                                                                                                          |
|       |          | 01 | 1 event has occurred.                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 10 | 2 events have occurred.                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | 11 | 3 events have occurred.                                                                                                                                                                                                                                                                                                                                                                           |
| 13-12 | SOCBPRD  |    | ePWM ADC Start-of-Conversion B Event (EPWMxSOCB) Period Select                                                                                                                                                                                                                                                                                                                                    |
|       |          |    | These bits determine how many selected ETSEL[SOCBSEL] events need to occur before an EPWMxSOCB pulse is generated. To be generated, the pulse must be enabled (ETSEL[SOCBEN] = 1). The SOCB pulse will be generated even if the status flag is set from a previous start of conversion (ETFLG[SOCB] = 1). Once the SOCB pulse is generated, the ETPS[SOCBCNT] bits will automatically be cleared. |
|       |          | 00 | Disable the SOCB event counter. No EPWMxSOCB pulse will be generated                                                                                                                                                                                                                                                                                                                              |
|       |          | 01 | Generate the EPWMxSOCB pulse on the first event: ETPS[SOCBCNT] = 0,1                                                                                                                                                                                                                                                                                                                              |
|       |          | 10 | Generate the EPWMxSOCB pulse on the second event: ETPS[SOCBCNT] = 1,0                                                                                                                                                                                                                                                                                                                             |
|       |          | 11 | Generate the EPWMxSOCB pulse on the third event: ETPS[SOCBCNT] = 1,1                                                                                                                                                                                                                                                                                                                              |
| 11-10 | SOCACNT  |    | ePWM ADC Start-of-Conversion A Event (EPWMxSOCA) Counter Register                                                                                                                                                                                                                                                                                                                                 |
|       |          |    | These bits indicate how many selected ETSEL[SOCASEL] events have occurred:                                                                                                                                                                                                                                                                                                                        |
|       |          | 00 | No events have occurred.                                                                                                                                                                                                                                                                                                                                                                          |
|       |          | 01 | 1 event has occurred.                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 10 | 2 events have occurred.                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | 11 | 3 events have occurred.                                                                                                                                                                                                                                                                                                                                                                           |
| 9-8   | SOCAPRD  |    | ePWM ADC Start-of-Conversion A Event (EPWMxSOCA) Period Select                                                                                                                                                                                                                                                                                                                                    |
|       |          |    | These bits determine how many selected ETSEL[SOCASEL] events need to occur before an EPWMxSOCA pulse is generated. To be generated, the pulse must be enabled (ETSEL[SOCAEN] = 1). The SOCA pulse will be generated even if the status flag is set from a previous start of conversion (ETFLG[SOCA] = 1). Once the SOCA pulse is generated, the ETPS[SOCACNT] bits will automatically be cleared. |
|       |          | 00 | Disable the SOCA event counter. No EPWMxSOCA pulse will be generated                                                                                                                                                                                                                                                                                                                              |
|       |          | 01 | Generate the EPWMxSOCA pulse on the first event: ETPS[SOCACNT] = 0,1                                                                                                                                                                                                                                                                                                                              |
|       |          | 10 | Generate the EPWMxSOCA pulse on the second event: ETPS[SOCACNT] = 1,0                                                                                                                                                                                                                                                                                                                             |
|       |          | 11 | Generate the EPWMxSOCA pulse on the third event: ETPS[SOCACNT] = 1,1                                                                                                                                                                                                                                                                                                                              |
| 7-4   | Reserved |    | Reserved                                                                                                                                                                                                                                                                                                                                                                                          |
| 3-2   | INTCNT   |    | ePWM Interrupt Event (EPWMx_INT) Counter Register                                                                                                                                                                                                                                                                                                                                                 |
|       |          |    | These bits indicate how many selected ETSEL[INTSEL] events have occurred. These bits ar automatically cleared when an interrupt pulse is generated. If interrupts are disabled, ETSEL[INT] = 0 or the interrupt flag is set, ETFLG[INT] = 1, the counter will stop counting events when it reaches the period value ETPS[INTCNT] = ETPS[INTPRD].                                                  |
|       |          | 00 | No events have occurred.                                                                                                                                                                                                                                                                                                                                                                          |
|       |          | 01 | 1 event has occurred.                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 10 | 2 events have occurred.                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | 11 | 3 events have occurred.                                                                                                                                                                                                                                                                                                                                                                           |

| www.ti.com |
|------------|
|------------|

| Bits | Name   |    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0  | INTPRD |    | ePWM Interrupt (EPWMx_INT) Period Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|      |        |    | These bits determine how many selected ETSEL[INTSEL] events need to occur before an interrupt is generated. To be generated, the interrupt must be enabled (ETSEL[INT] = 1). If the interrupt status flag is set from a previous interrupt (ETFLG[INT] = 1) then no interrupt will be generated until the flag is cleared via the ETCLR[INT] bit. This allows for one interrupt to be pending while another is still being serviced. Once the interrupt is generated, the ETPS[INTCNT] bits will automatically be cleared. |
|      |        |    | Writing a INTPRD value that is the same as the current counter value will trigger an interrupt if it is enabled and the status flag is clear.                                                                                                                                                                                                                                                                                                                                                                              |
|      |        |    | Writing a INTPRD value that is less than the current counter value will result in an undefined state.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|      |        |    | If a counter event occurs at the same instant as a new zero or non-zero INTPRD value is written, the counter is incremented.                                                                                                                                                                                                                                                                                                                                                                                               |
|      |        | 00 | Disable the interrupt event counter. No interrupt will be generated and ETFRC[INT] is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|      |        | 01 | Generate an interrupt on the first event INTCNT = 01 (first event)                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|      |        | 10 | Generate interrupt on ETPS[INTCNT] = 1,0 (second event)                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |        | 11 | Generate interrupt on ETPS[INTCNT] = 1,1 (third event)                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## Table 3-57. Event-Trigger Prescale Register (ETPS) Field Descriptions (continued)

# Figure 3-106. Event-Trigger Flag Register (ETFLG)

| 15 |          |      |       |      |          | 8   |
|----|----------|------|-------|------|----------|-----|
|    |          | Rese | erved |      |          |     |
|    |          | R    | -0    |      |          |     |
| 7  |          | 4    | 3     | 2    | 1        | 0   |
|    | Reserved |      | SOCB  | SOCA | Reserved | INT |
|    | R-0      |      | R-0   | R-0  | R-0      | R-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 3-58. Event-Trigger Flag Register (ETFLG) Field Descriptions

| Bits | Name     | Value | Description                                                                                                                                                                                                                                                                                                                         |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4 | Reserved |       | Reserved                                                                                                                                                                                                                                                                                                                            |
| 3    | SOCB     |       | Latched ePWM ADC Start-of-Conversion B (EPWMxSOCB) Status Flag                                                                                                                                                                                                                                                                      |
|      |          | 0     | Indicates no EPWMxSOCB event occurred                                                                                                                                                                                                                                                                                               |
|      |          | 1     | Indicates that a start of conversion pulse was generated on EPWMxSOCB. The EPWMxSOCB output will continue to be generated even if the flag bit is set.                                                                                                                                                                              |
| 2    | SOCA     |       | Latched ePWM ADC Start-of-Conversion A (EPWMxSOCA) Status Flag                                                                                                                                                                                                                                                                      |
|      |          |       | Unlike the ETFLG[INT] flag, the EPWMxSOCA output will continue to pulse even if the flag bit is set.                                                                                                                                                                                                                                |
|      |          | 0     | Indicates no event occurred                                                                                                                                                                                                                                                                                                         |
|      |          | 1     | Indicates that a start of conversion pulse was generated on EPWMxSOCA. The EPWMxSOCA output will continue to be generated even if the flag bit is set.                                                                                                                                                                              |
| 1    | Reserved |       | Reserved                                                                                                                                                                                                                                                                                                                            |
| 0    | INT      |       | Latched ePWM Interrupt (EPWMx_INT) Status Flag                                                                                                                                                                                                                                                                                      |
|      |          | 0     | Indicates no event occurred                                                                                                                                                                                                                                                                                                         |
|      |          | 1     | Indicates that an ePWMx interrupt (EWPMx_INT) was generated. No further interrupts will be generated until the flag bit is cleared. Up to one interrupt can be pending while the ETFLG[INT] bit is still set. If an interrupt is pending, it will not be generated until after the ETFLG[INT] bit is cleared. Refer to Figure 3-42. |



Registers

|    | Figure   | 3-107. Event-T | rigger Clear Ro | egister (ETC | _R)      |       |
|----|----------|----------------|-----------------|--------------|----------|-------|
| 15 |          |                |                 |              |          | 8     |
|    |          | Res            | erved           |              |          |       |
|    |          | R              | = 0             |              |          |       |
| 7  |          | 4              | 3               | 2            | 1        | 0     |
|    | Reserved |                | SOCB            | SOCA         | Reserved | INT   |
|    | R-0      |                | R/W-0           | R/W-0        | R-0      | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bits | Name     | Value | Description                                                                         |
|------|----------|-------|-------------------------------------------------------------------------------------|
| 15-4 | Reserved |       | Reserved                                                                            |
| 3    | SOCB     |       | ePWM ADC Start-of-Conversion B (EPWMxSOCB) Flag Clear Bit                           |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0                                    |
|      |          | 1     | Clears the ETFLG[SOCB] flag bit                                                     |
| 2    | SOCA     |       | ePWM ADC Start-of-Conversion A (EPWMxSOCA) Flag Clear Bit                           |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0                                    |
|      |          | 1     | Clears the ETFLG[SOCA] flag bit                                                     |
| 1    | Reserved |       | Reserved                                                                            |
| 0    | INT      |       | ePWM Interrupt (EPWMx_INT) Flag Clear Bit                                           |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0                                    |
|      |          | 1     | Clears the ETFLG[INT] flag bit and enable further interrupts pulses to be generated |

#### Table 3-59. Event-Trigger Clear Register (ETCLR) Field Descriptions

#### Figure 3-108. Event-Trigger Force Register (ETFRC)

| 15 |          |     |       |       |          | 8     |
|----|----------|-----|-------|-------|----------|-------|
|    |          | Res | erved |       |          |       |
|    |          | F   | २-०   |       |          |       |
| 7  |          | 4   | 3     | 2     | 1        | 0     |
|    | Reserved |     | SOCB  | SOCA  | Reserved | INT   |
|    | R-0      |     | R/W-0 | R/W-0 | R-0      | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 3-60. Event-Trigger Force Register (ETFRC) Field Descriptions

| Bits | Name     | Value | Description                                                                                                                                           |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4 | Reserved |       | Reserved                                                                                                                                              |
| 3    | SOCB     |       | SOCB Force Bit. The SOCB pulse will only be generated if the event is enabled in the ETSEL register. The ETFLG[SOCB] flag bit will be set regardless. |
|      |          | 0     | Has no effect. Always reads back a 0.                                                                                                                 |
|      |          | 1     | Generates a pulse on EPWMxSOCB and sets the SOCBFLG bit. This bit is used for test purposes.                                                          |
| 2    | SOCA     |       | SOCA Force Bit. The SOCA pulse will only be generated if the event is enabled in the ETSEL register. The ETFLG[SOCA] flag bit will be set regardless. |
|      |          | 0     | Writing 0 to this bit will be ignored. Always reads back a 0.                                                                                         |
|      |          | 1     | Generates a pulse on EPWMxSOCA and set the SOCAFLG bit. This bit is used for test purposes.                                                           |
| 1    | Reserved | 0     | Reserved                                                                                                                                              |
| 0    | INT      |       | INT Force Bit. The interrupt will only be generated if the event is enabled in the ETSEL register. The INT flag bit will be set regardless.           |
|      |          | 0     | Writing 0 to this bit will be ignored. Always reads back a 0.                                                                                         |
|      |          | 1     | Generates an interrupt on EPWMxINT and set the INT flag bit. This bit is used for test purposes.                                                      |



#### Registers

#### 3.4.9 Proper Interrupt Initialization Procedure

When the ePWM peripheral clock is enabled it may be possible that interrupt flags may be set due to spurious events due to the ePWM registers not being properly initialized. The proper procedure for initializing the ePWM peripheral is as follows:

- 1. Disable global interrupts (CPU INTM flag)
- 2. Disable ePWM interrupts
- 3. Set TBCLKSYNC=0
- 4. Initialize peripheral registers
- 5. Set TBCLKSYNC=1
- 6. Clear any spurious ePWM flags (including PIEIFR)
- 7. Enable ePWM interrupts
- 8. Enable global interrupts



Page

# Enhanced Capture (eCAP) Module

The enhanced Capture (eCAP) module is essential in systems where accurate timing of external events is important.

#### Topic

| 4.1 | Introduction                                  |     |
|-----|-----------------------------------------------|-----|
| 4.2 | Description                                   | 378 |
| 4.3 | Capture and APWM Operating Mode               | 379 |
| 4.4 | Capture Mode Description                      | 381 |
| 4.5 | Capture Module - Control and Status Registers | 387 |
| 4.6 | Register Mapping                              | 395 |
| 4.7 | Application of the ECAP Module                | 395 |
| 4.8 | Application of the APWM Mode                  | 405 |
|     |                                               |     |



Introduction

# 4.1 Introduction

Uses for eCAP include:

- Speed measurements of rotating machinery (for example, toothed sprockets sensed via Hall sensors)
- Elapsed time measurements between position sensor pulses
- Period and duty cycle measurements of pulse train signals
- Decoding current or voltage amplitude derived from duty cycle encoded current/voltage sensors

The eCAP module described in this guide includes the following features:

- 4-event time-stamp registers (each 32 bits)
- Edge polarity selection for up to four sequenced time-stamp capture events
- Interrupt on either of the four events
- · Single shot capture of up to four event time-stamps
- Continuous mode capture of time-stamps in a four-deep circular buffer
- Absolute time-stamp capture
- Difference (Delta) mode time-stamp capture
- All above resources dedicated to a single input pin
- When not used in capture mode, the ECAP module can be configured as a single channel PWM output

#### 4.2 Description

The eCAP module represents one complete capture channel that can be instantiated multiple times depending on the target device. In the context of this guide, one eCAP channel has the following independent key resources:

- Dedicated input capture pin
- 32-bit time base (counter)
- 4 x 32-bit time-stamp capture registers (CAP1-CAP4)
- 4-stage sequencer (Modulo4 counter) that is synchronized to external events, ECAP pin rising/falling edges.
- Independent edge polarity (rising/falling edge) selection for all 4 events
- Input capture signal prescaling (from 2-62)
- One-shot compare register (2 bits) to freeze captures after 1 to 4 time-stamp events
- Control for continuous time-stamp captures using a 4-deep circular buffer (CAP1-CAP4) scheme
- Interrupt capabilities on any of the 4 capture events



# 4.3 Capture and APWM Operating Mode

You can use the eCAP module resources to implement a single-channel PWM generator (with 32-bit capabilities) when it is not being used for input captures. The counter operates in count-up mode, providing a time-base for asymmetrical pulse width modulation (PWM) waveforms. The CAP1 and CAP2 registers become the active period and compare registers, respectively, while CAP3 and CAP4 registers become the period and capture shadow registers, respectively. Figure 4-1 is a high-level view of both the capture and auxiliary pulse-width modulator (APWM) modes of operation.



Figure 4-1. Capture and APWM Modes of Operation

- A A single pin is shared between CAP and APWM functions. In capture mode, it is an input; in APWM mode, it is an output.
- B In APWM mode, writing any value to CAP1/CAP2 active registers also writes the same value to the corresponding shadow registers CAP3/CAP4. This emulates immediate mode. Writing to the shadow registers CAP3/CAP4 invokes the shadow mode.

Figure 4-2 further descries the output of the eCAP in APWM mode based on the CMP and PRD values.



# Figure 4-2. Counter Compare and PRD Effects on the eCAP Output in APWM Mode



# 4.4 Capture Mode Description

Figure 4-3 shows the various components that implement the capture function.



#### Figure 4-3. Capture Function Diagram

Capture Mode Description



#### Capture Mode Description

#### 4.4.1 Event Prescaler

An input capture signal (pulse train) can be prescaled by N = 2-62 (in multiples of 2) or can bypass the
prescaler.

This is useful when very high frequency signals are used as inputs. Figure 4-4 shows a functional diagram and Figure 4-5 shows the operation of the prescale function.



#### Figure 4-4. Event Prescale Control

A When a prescale value of 1 is chosen (ECCTL1[13:9] = 0,0,0,0,0) the input capture signal bypasses the prescale logic completely.



#### Figure 4-5. Prescale Function Waveforms

#### 4.4.2 Edge Polarity Select and Qualifier

- Four independent edge polarity (rising edge/falling edge) selection MUXes are used, one for each capture event.
- Each edge (up to 4) is event qualified by the Modulo4 sequencer.
- The edge event is gated to its respective CAPx register by the Mod4 counter. The CAPx register is loaded on the falling edge.

# 4.4.3 Continuous/One-Shot Control

• The Mod4 (2 bit) counter is incremented via edge qualified events (CEVT1-CEVT4).



- The Mod4 counter continues counting (0->1->2->3->0) and wraps around unless stopped.
- A 2-bit stop register is used to compare the Mod4 counter output, and when equal stops the Mod4 counter and inhibits further loads of the CAP1-CAP4 registers. This occurs during one-shot operation.

The continuous/one-shot block controls the start/stop and reset (zero) functions of the Mod4 counter via a mono-shot type of action that can be triggered by the stop-value comparator and re-armed via software control.

Once armed, the eCAP module waits for 1-4 (defined by stop-value) capture events before freezing both the Mod4 counter and contents of CAP1-4 registers (time-stamps).

Re-arming prepares the eCAP module for another capture sequence. Also re-arming clears (to zero) the Mod4 counter and permits loading of CAP1-4 registers again, providing the CAPLDEN bit is set.

In continuous mode, the Mod4 counter continues to run (0->1->2->3->0, the one-shot action is ignored, and capture values continue to be written to CAP1-4 in a circular buffer sequence.

Figure 4-6. Details of the Continuous/One-shot Block



# 4.4.4 32-Bit Counter and Phase Control

This counter provides the time-base for event captures, and is clocked via the system clock.

A phase register is provided to achieve synchronization with other counters, via a hardware and software forced sync. This is useful in APWM mode when a phase offset between modules is needed.

On any of the four event loads, an option to reset the 32-bit counter is given. This is useful for time difference capture. The 32-bit counter value is captured first, then it is reset to 0 by any of the LD1-LD4 signals.



# Figure 4-7. Details of the Counter and Synchronization Block

# 4.4.5 CAP1-CAP4 Registers

These 32-bit registers are fed by the 32-bit counter timer bus, CTR[0-31] and are loaded (capture a timestamp) when their respective LD inputs are strobed.

Loading of the capture registers can be inhibited via control bit CAPLDEN. During one-shot operation, this bit is cleared (loading is inhibited) automatically when a stop condition occurs, that is, StopValue = Mod4.

CAP1 and CAP2 registers become the active period and compare registers, respectively, in APWM mode.

CAP3 and CAP4 registers become the respective shadow registers (APRD and ACMP) for CAP1 and CAP2 during APWM operation.

# 4.4.6 Interrupt Control

An Interrupt can be generated on capture events (CEVT1-CEVT4, CTROVF) or APWM events (CTR = PRD, CTR = CMP).

A counter overflow event (FFFFFFF->00000000) is also provided as an interrupt source (CTROVF).

The capture events are edge and sequencer qualified (ordered in time) by the polarity select and Mod4 gating, respectively.

One of these events can be selected as the interrupt source (from the eCAPx module) going to the PIE.

Seven interrupt events (CEVT1, CEVT2, CEVT3, CEVT4, CNTOVF, CTR=PRD, CTR=CMP) can be generated. The interrupt enable register (ECEINT) is used to enable/disable individual interrupt event sources. The interrupt flag register (ECFLG) indicates if any interrupt event has been latched and contains the global interrupt flag bit (INT). An interrupt pulse is generated to the PIE only if any of the interrupt events are enabled, the flag bit is 1, and the INT flag bit is 0. The interrupt service routine must clear the global interrupt flag bit and the serviced event via the interrupt clear register (ECCLR) before any other interrupt pulses are generated. You can force an interrupt event via the interrupt force register (ECFRC). This is useful for test purposes.



**Note:** The CEVT1, CEVT2, CEVT3, CEVT4 flags are only active in capture mode (ECCTL2[CAP/APWM == 0]). The CTR=PRD, CTR=CMP flags are only valid in APWM mode (ECCTL2[CAP/APWM == 1]). CNTOVF flag is valid in both modes.



## Figure 4-8. Interrupts in eCAP Module

# 4.4.7 Shadow Load and Lockout Control

In capture mode, this logic inhibits (locks out) any shadow loading of CAP1 or CAP2 from APRD and ACMP registers, respectively.

In APWM mode, shadow loading is active and two choices are permitted:

- Immediate APRD or ACMP are transferred to CAP1 or CAP2 immediately upon writing a new value.
- On period equal, that is, CTR[31:0] = PRD[31:0]

# 4.4.8 APWM Mode Operation

Main operating highlights of the APWM section:

- The time-stamp counter bus is made available for comparison via 2 digital (32-bit) comparators.
- When CAP1/2 registers are not used in capture mode, their contents can be used as Period and Compare values in APWM mode.
- Double buffering is achieved via shadow registers APRD and ACMP (CAP3/4). The shadow register
  contents are transferred over to CAP1/2 registers either immediately upon a write, or on a CTR = PRD
  trigger.
- In APWM mode, writing to CAP1/CAP2 active registers will also write the same value to the corresponding shadow registers CAP3/CAP4. This emulates immediate mode. Writing to the shadow registers CAP3/CAP4 will invoke the shadow mode.
- During initialization, you must write to the active registers for both period and compare. This automatically copies the initial values into the shadow values. For subsequent compare updates (during run-time), you only need to use the shadow registers.



#### Figure 4-9. PWM Waveform Details Of APWM Mode Operation

The behavior of APWM active high mode (APWMPOL == 0) is as follows:

CMP = 0x00000000, output low for duration of period (0% duty)

CMP = 0x00000001, output high 1 cycle

CMP = 0x00000002, output high 2 cycles

CMP = PERIOD, output high except for 1 cycle (<100% duty)

CMP = PERIOD+1, output high for complete period (100% duty)

CMP > PERIOD+1, output high for complete period

#### The behavior of APWM active low mode (APWMPOL == 1) is as follows:

- CMP = 0x00000000, output high for duration of period (0% duty)
- CMP = 0x00000001, output low 1 cycle
- CMP = 0x00000002, output low 2 cycles
- CMP = PERIOD, output low except for 1 cycle (<100% duty)
- CMP = PERIOD+1, output low for complete period (100% duty)
- CMP > PERIOD+1, output low for complete period



0

0

# 4.5 Capture Module - Control and Status Registers

#### Figure 4-10. Time-Stamp Counter Register (TSCTR)

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

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 4-1. Time-Stamp Counter Register (TSCTR) Field Descriptions

| Bit(s) | Field | Description                                                          |
|--------|-------|----------------------------------------------------------------------|
| 31:0   | TSCTR | Active 32-bit counter register that is used as the capture time-base |

#### Figure 4-11. Counter Phase Control Register (CTRPHS)

31

CTRPHS R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 4-2. Counter Phase Control Register (CTRPHS) Field Descriptions

| Bit(s) | Field  | Description                                                                                                                                                                                                                                                                          |
|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | CTRPHS | Counter phase value register that can be programmed for phase lag/lead. This register shadows TSCTR and is loaded into TSCTR upon either a SYNCI event or S/W force via a control bit. Used to achieve phase control synchronization with respect to other eCAP and EPWM time-bases. |

#### Figure 4-12. Capture-1 Register (CAP1)

| 31 |       | 0 |
|----|-------|---|
|    | CAP1  |   |
|    | R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 4-3. Capture-1 Register (CAP1) Field Descriptions

| Bit(s) | Field | Description                                                                                                                                                                                                          |
|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | CAP1  | This register can be loaded (written) by :) Time-Stamp (counter value TSCTR) during a capture event) Software - may be useful for test purposes / initialization) APRD shadow register (CAP3) when used in APWM mode |

#### Figure 4-13. Capture-2 Register (CAP2)

31

| CAP2  |  |
|-------|--|
| R/W-0 |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 4-4. Capture-2 Register (CAP2) Field Descriptions

| Bit(s) | Field | Description                                        |
|--------|-------|----------------------------------------------------|
| 31:0   | CAP2  | This register can be loaded (written) by:          |
|        |       | Time-Stamp ( counter value) during a capture event |
|        |       | Software - may be useful for test purposes         |
|        |       | APRD shadow register (CAP4) when used in APWM mode |



# **NOTE:** In APWM mode, writing to CAP1/CAP2 active registers also writes the same value to the corresponding shadow registers CAP3/CAP4. This emulates immediate mode. Writing to the shadow registers CAP3/CAP4 invokes the shadow mode.

#### Figure 4-14. Capture-3 Register (CAP3)

| 31 |       | 0 |
|----|-------|---|
|    | CAP3  |   |
|    | R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 4-5. Capture-3 Register (CAP3) Field Descriptions

| Bit(s) | Field | Description                                                                                                                                                                                                 |
|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | CAP3  | In CMP mode, this is a time-stamp capture register. In APWM mode, this is the period shadow (APRD) register. You update the PWM period value through this register. In this mode, CAP3 (APRD) shadows CAP1. |

#### Figure 4-15. Capture-4 Register (CAP4)

| 31 |       | 0 |
|----|-------|---|
|    | CAP4  |   |
|    | R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 4-6. Capture-4 Register (CAP4) Field Descriptions

| Bit(s) | Field | Description                                                                                                                                                                                               |
|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | CAP4  | In CMP mode, this is a time-stamp capture register. In APWM mode, this is the compare shadow (ACMP) register. You update the PWM compare value via this register. In this mode, CAP4 (ACMP) shadows CAP2. |

#### Figure 4-16. ECAP Control Register 1 (ECCTL1)

| 15      | 14      | 13                    | 12      | 11       | 10      | 9       | 8       |
|---------|---------|-----------------------|---------|----------|---------|---------|---------|
| FREE    | E/SOFT  |                       |         | PRESCALE |         |         | CAPLDEN |
| R/      | W-0     |                       |         | R/W-0    |         |         | R/W-0   |
| 7       | 6       | 5                     | 4       | 3        | 2       | 1       | 0       |
| CTRRST4 | CAP4POL | CTRRST3               | CAP3POL | CTRRST2  | CAP2POL | CTRRST1 | CAP1POL |
| R/W-0   | R/W-0   | R/W-0                 | R/W-0   | R/W-0    | R/W-0   | R/W-0   | R/W-0   |
|         |         | Desident and a second |         |          |         |         |         |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 4-7. ECAP Control Register 1 (ECCTL1) Field Descriptions

| Bit(s) | Field         | Value | Description                                                 |  |  |  |  |  |
|--------|---------------|-------|-------------------------------------------------------------|--|--|--|--|--|
| 15:14  | FREE/SOFT     |       | Emulation Control                                           |  |  |  |  |  |
|        |               | 00    | TSCTR counter stops immediately on emulation suspend        |  |  |  |  |  |
|        |               | 01    | TSCTR counter runs until = 0                                |  |  |  |  |  |
|        |               | 1x    | TSCTR counter is unaffected by emulation suspend (Run Free) |  |  |  |  |  |
| 13:9   | 13:9 PRESCALE |       | Event Filter prescale select                                |  |  |  |  |  |
|        |               | 00000 | Divide by 1 (i.e,. no prescale, by-pass the prescaler)      |  |  |  |  |  |
|        |               | 00001 | Divide by 2                                                 |  |  |  |  |  |
|        |               | 00010 | Divide by 4                                                 |  |  |  |  |  |
|        |               | 00011 | Divide by 6                                                 |  |  |  |  |  |



| Bit(s) | Field   | Value | Description                                                                                          |
|--------|---------|-------|------------------------------------------------------------------------------------------------------|
|        |         | 00100 | Divide by 8                                                                                          |
|        |         | 00101 | Divide by 10                                                                                         |
|        |         |       |                                                                                                      |
|        |         | 11110 | Divide by 60                                                                                         |
|        |         | 11111 | Divide by 62                                                                                         |
| 8      | CAPLDEN |       | Enable Loading of CAP1-4 registers on a capture event                                                |
|        |         | 0     | Disable CAP1-4 register loads at capture event time.                                                 |
|        |         | 1     | Enable CAP1-4 register loads at capture event time.                                                  |
| 7      | CTRRST4 |       | Counter Reset on Capture Event 4                                                                     |
|        |         | 0     | Do not reset counter on Capture Event 4 (absolute time stamp operation)                              |
|        |         | 1     | Reset counter after Capture Event 4 time-stamp has been captured (used in difference mode operation) |
| 6      | CAP4POL |       | Capture Event 4 Polarity select                                                                      |
|        |         | 0     | Capture Event 4 triggered on a rising edge (RE)                                                      |
|        |         | 1     | Capture Event 4 triggered on a falling edge (FE)                                                     |
| 5      | CTRRST3 |       | Counter Reset on Capture Event 3                                                                     |
|        |         | 0     | Do not reset counter on Capture Event 3 (absolute time stamp)                                        |
|        |         | 1     | Reset counter after Event 3 time-stamp has been captured (used in difference mode operation)         |
| 4      | CAP3POL |       | Capture Event 3 Polarity select                                                                      |
|        |         | 0     | Capture Event 3 triggered on a rising edge (RE)                                                      |
|        |         | 1     | Capture Event 3 triggered on a falling edge (FE)                                                     |
| 3      | CTRRST2 |       | Counter Reset on Capture Event 2                                                                     |
|        |         | 0     | Do not reset counter on Capture Event 2 (absolute time stamp)                                        |
|        |         | 1     | Reset counter after Event 2 time-stamp has been captured (used in difference mode operation)         |
| 2      | CAP2POL |       | Capture Event 2 Polarity select                                                                      |
|        |         | 0     | Capture Event 2 triggered on a rising edge (RE)                                                      |
|        |         | 1     | Capture Event 2 triggered on a falling edge (FE)                                                     |
| 1      | CTRRST1 |       | Counter Reset on Capture Event 1                                                                     |
|        |         | 0     | Do not reset counter on Capture Event 1 (absolute time stamp)                                        |
|        |         | 1     | Reset counter after Event 1 time-stamp has been captured (used in difference mode operation)         |
| 0      | CAP1POL |       | Capture Event 1 Polarity select                                                                      |
|        |         | 0     | Capture Event 1 triggered on a rising edge (RE)                                                      |
|        |         | 1     | Capture Event 1 triggered on a falling edge (FE)                                                     |

#### Table 4-7. ECAP Control Register 1 (ECCTL1) Field Descriptions (continued)

# Figure 4-17. ECAP Control Register 2 (ECCTL2)

| 15   |           |          |           | 11    | 10      | 9        | 8               |
|------|-----------|----------|-----------|-------|---------|----------|-----------------|
|      |           | Reserved |           |       | APWMPOL | CAP/APWM | SWSYNC          |
|      |           | R-0      |           |       | R/W-0   | R/W-0    | R/W-0           |
| 7    | 6         | 5        | 4         | 3     | 2       | 1        | 0               |
| SYNC | SYNCO_SEL |          | TSCTRSTOP | REARM | STOP_   | WRAP     | CONT/ONESH<br>T |
| RA   | R/W-0     |          | R/W-0     | R/W-0 | R/W-1   | R/W-1    | R/W-0           |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



# Table 4-8. ECAP Control Register 2 (ECCTL2) Field Descriptions

| Bit(s) | Field     |    | Description                                                                                                                                                                                                                                                                                                                             |
|--------|-----------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:11  | Reserved  |    | Reserved                                                                                                                                                                                                                                                                                                                                |
| 10     | APWMPOL   |    | APWM output polarity select. This is applicable only in APWM operating mode                                                                                                                                                                                                                                                             |
|        |           | 0  | Output is active high (Compare value defines high time)                                                                                                                                                                                                                                                                                 |
|        |           | 1  | Output is active low (Compare value defines low time)                                                                                                                                                                                                                                                                                   |
| 9      | CAP/APWM  |    | CAP/APWM operating mode select                                                                                                                                                                                                                                                                                                          |
|        |           | 0  | <ul> <li>ECAP module operates in capture mode. This mode forces the following configuration:</li> <li>Inhibits TSCTR resets via CTR = PRD event</li> <li>Inhibits shadow loads on CAP1 and 2 registers</li> <li>Permits user to enable CAP1-4 register load</li> <li>CAPx/APWMx pin operates as a capture input</li> </ul>              |
|        |           | 1  | <ul> <li>ECAP module operates in APWM mode. This mode forces the following configuration:</li> <li>Resets TSCTR on CTR = PRD event (period boundary</li> <li>Permits shadow loading on CAP1 and 2 registers</li> <li>Disables loading of time-stamps into CAP1-4 registers</li> <li>CAPx/APWMx pin operates as a APWM output</li> </ul> |
| 8      | SWSYNC    |    | Software-forced Counter (TSCTR) Synchronizing. This provides a convenient software method to synchronize some or all ECAP time bases. In APWM mode, the synchronizing can also be done via the CTR = PRD event.                                                                                                                         |
|        |           | 0  | Writing a zero has no effect. Reading always returns a zero                                                                                                                                                                                                                                                                             |
|        |           | 1  | Writing a one forces a TSCTR shadow load of current ECAP module and any ECAP modules down-stream providing the SYNCO_SEL bits are 0,0. After writing a 1, this bit returns to a zero.                                                                                                                                                   |
|        |           |    | Note: Selection CTR = PRD is meaningful only in APWM mode; however, you ca choose it in CAP mode if you find doing so useful.                                                                                                                                                                                                           |
| 7:6    | SYNCO_SEL |    | Sync-Out Select                                                                                                                                                                                                                                                                                                                         |
|        |           | 00 | Select sync-in event to be the sync-out signal (pass through)                                                                                                                                                                                                                                                                           |
|        |           | 01 | Select CTR = PRD event to be the sync-out signal                                                                                                                                                                                                                                                                                        |
|        |           | 10 | Disable sync out signal                                                                                                                                                                                                                                                                                                                 |
|        |           | 11 | Disable sync out signal                                                                                                                                                                                                                                                                                                                 |
| 5      | SYNCI_EN  |    | Counter (TSCTR) Sync-In select mode                                                                                                                                                                                                                                                                                                     |
|        |           | 0  | Disable sync-in option                                                                                                                                                                                                                                                                                                                  |
|        |           | 1  | Enable counter (TSCTR) to be loaded from CTRPHS register upon either a SYN signal or a S/W force event.                                                                                                                                                                                                                                 |
| 4      | TSCTRSTOP |    | Time Stamp (TSCTR) Counter Stop (freeze) Control                                                                                                                                                                                                                                                                                        |
|        |           | 0  | TSCTR stopped                                                                                                                                                                                                                                                                                                                           |
|        |           | 1  | TSCTR free-running                                                                                                                                                                                                                                                                                                                      |
| 3      | RE-ARM    |    | One-Shot Re-Arming Control, that is, wait for stop trigger. Note: The re-arm function is valid in one shot or continuous mode.                                                                                                                                                                                                          |
|        |           | 0  | Has no effect (reading always returns a 0)                                                                                                                                                                                                                                                                                              |
|        |           | 1  | Arms the one-shot sequence as follows:<br>1) Resets the Mod4 counter to zero<br>2) Unfreezes the Mod4 counter<br>3) Enables capture register loads                                                                                                                                                                                      |
| 2:1    | STOP_WRAP |    | Stop value for one-shot mode. This is the number (between 1-4) of captures allowed to occur before the CAP(1-4) registers are frozen, that is, capture sequence is stopped.<br>Wrap value for continuous mode. This is the number (between 1-4) of the capture register in which the circular buffer wraps around and starts again.     |
|        |           | 00 | Stop after Capture Event 1 in one-shot mode<br>Wrap after Capture Event 1 in continuous mode.                                                                                                                                                                                                                                           |
|        |           | 01 | Stop after Capture Event 2 in one-shot mode<br>Wrap after Capture Event 2 in continuous mode.                                                                                                                                                                                                                                           |



| Bit(s) | Field       |    | Description                                                                                                 |
|--------|-------------|----|-------------------------------------------------------------------------------------------------------------|
|        |             | 10 | Stop after Capture Event 3 in one-shot mode<br>Wrap after Capture Event 3 in continuous mode.               |
|        |             | 11 | Stop after Capture Event 4 in one-shot mode<br>Wrap after Capture Event 4 in continuous mode.               |
|        |             |    | Notes: STOP_WRAP is compared to Mod4 counter and, when equal, 2 actions occur:                              |
|        |             |    | <ul> <li>Mod4 counter is stopped (frozen)</li> </ul>                                                        |
|        |             |    | Capture register loads are inhibited In one-shot mode, further interrupt events are blocked until re-armed. |
| 0      | CONT/ONESHT |    | Continuous or one-shot mode control (applicable only in capture mode)                                       |
|        |             | 0  | Operate in continuous mode                                                                                  |
|        |             | 1  | Operate in one-Shot mode                                                                                    |

# Table 4-8. ECAP Control Register 2 (ECCTL2) Field Descriptions (continued)



#### Capture Module - Control and Status Registers

www.ti.com

| Figure 4-18. ECA | Interrupt Enable | Register (ECEINT) |
|------------------|------------------|-------------------|
|                  |                  |                   |

| 15      |          |        |       |       |       |       | 8        |  |  |  |
|---------|----------|--------|-------|-------|-------|-------|----------|--|--|--|
|         | Reserved |        |       |       |       |       |          |  |  |  |
| 7       | 6        | 5      | 4     | 3     | 2     | 1     | 0        |  |  |  |
| CTR=CMP | CTR=PRD  | CTROVF | CEVT4 | CEVT3 | CEVT2 | CETV1 | Reserved |  |  |  |
|         |          | R/W    | R/W   | R/W   | R/W   | R/W   |          |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 4-9. ECAP Interrupt Enable Register (ECEINT) Field Descriptions

| Bits | Field    | Value | Description                                      |
|------|----------|-------|--------------------------------------------------|
| 15:8 | Reserved |       |                                                  |
| 7    | CTR=CMP  |       | Counter Equal Compare Interrupt Enable           |
|      |          | 0     | Disable Compare Equal as an Interrupt source     |
|      |          | 1     | Enable Compare Equal as an Interrupt source      |
| 6    | CTR=PRD  |       | Counter Equal Period Interrupt Enable            |
|      |          | 0     | Disable Period Equal as an Interrupt source      |
|      |          | 1     | Enable Period Equal as an Interrupt source       |
| 5    | CTROVF   |       | Counter Overflow Interrupt Enable                |
|      |          | 0     | Disabled counter Overflow as an Interrupt source |
|      |          | 1     | Enable counter Overflow as an Interrupt source   |
| 4    | CEVT4    |       | Capture Event 4 Interrupt Enable                 |
|      |          | 0     | Disable Capture Event 4 as an Interrupt source   |
|      |          | 1     | Capture Event 4 Interrupt Enable                 |
| 3    | CEVT3    |       | Capture Event 3 Interrupt Enable                 |
|      |          | 0     | Disable Capture Event 3 as an Interrupt source   |
|      |          | 1     | Enable Capture Event 3 as an Interrupt source    |
| 2    | CEVT2    |       | Capture Event 2 Interrupt Enable                 |
|      |          | 0     | Disable Capture Event 2 as an Interrupt source   |
|      |          | 1     | Enable Capture Event 2 as an Interrupt source    |
| 1    | CEVT1    |       | Capture Event 1 Interrupt Enable                 |
|      |          | 0     | Disable Capture Event 1 as an Interrupt source   |
|      |          | 1     | Enable Capture Event 1 as an Interrupt source    |
| 0    | Reserved |       |                                                  |

The interrupt enable bits (CEVT1, ...) block any of the selected events from generating an interrupt. Events will still be latched into the flag bit (ECFLG register) and can be forced/cleared via the ECFRC/ECCLR registers.

The proper procedure for configuring peripheral modes and interrupts is as follows:

- Disable global interrupts
- Stop eCAP counter
- Disable eCAP interrupts
- Configure peripheral registers
- Clear spurious eCAP interrupt flags
- Enable eCAP interrupts
- Start eCAP counter
- Enable global interrupts



Capture Module - Control and Status Registers

| Figure 4-19. ECAP Interrupt Flag Register (ECFLG) |                                                |     |     |       |     |     |     |  |  |  |
|---------------------------------------------------|------------------------------------------------|-----|-----|-------|-----|-----|-----|--|--|--|
| 15                                                |                                                | -   |     |       |     |     | 8   |  |  |  |
|                                                   |                                                |     | Res | erved |     |     |     |  |  |  |
|                                                   | R-0                                            |     |     |       |     |     |     |  |  |  |
| 7                                                 | 6                                              | 5   | 4   | 3     | 2   | 1   | 0   |  |  |  |
| CTR=CMP                                           | CTR=CMP CTR=PRD CTROVF CEVT4 CETV3 CEVT2 CETV1 |     |     |       |     |     |     |  |  |  |
| R-0                                               | R-0                                            | R-0 | R-0 | R-0   | R-0 | R-0 | R-0 |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

| Bits | Field    | Value | Description                                                                           |
|------|----------|-------|---------------------------------------------------------------------------------------|
| 15:8 | Reserved |       |                                                                                       |
| 7    | CTR=CMP  |       | Compare Equal Compare Status Flag. This flag is active only in APWM mode.             |
|      |          | 0     | Indicates no event occurred                                                           |
|      |          | 1     | Indicates the counter (TSCTR) reached the compare register value (ACMP)               |
| 6    | CTR=PRD  |       | Counter Equal Period Status Flag. This flag is only active in APWM mode.              |
|      |          | 0     | Indicates no event occurred                                                           |
|      |          | 1     | Indicates the counter (TSCTR) reached the period register value (APRD) and was reset. |
| 5    | CTROVF   |       | Counter Overflow Status Flag. This flag is active in CAP and APWM mode.               |
|      |          | 0     | Indicates no event occurred.                                                          |
|      |          | 1     | Indicates the counter (TSCTR) has made the transition from FFFFFFFF " 00000000        |
| 4    | CEVT4    |       | Capture Event 4 Status Flag This flag is only active in CAP mode.                     |
|      |          | 0     | Indicates no event occurred                                                           |
|      |          | 1     | Indicates the fourth event occurred at ECAPx pin                                      |
| 3    | CEVT3    |       | Capture Event 3 Status Flag. This flag is active only in CAP mode.                    |
|      |          | 0     | Indicates no event occurred.                                                          |
|      |          | 1     | Indicates the third event occurred at ECAPx pin.                                      |
| 2    | CEVT2    |       | Capture Event 2 Status Flag. This flag is only active in CAP mode.                    |
|      |          | 0     | Indicates no event occurred.                                                          |
|      |          | 1     | Indicates the second event occurred at ECAPx pin.                                     |
| 1    | CEVT1    |       | Capture Event 1 Status Flag. This flag is only active in CAP mode.                    |
|      |          | 0     | Indicates no event occurred.                                                          |
|      |          | 1     | Indicates the first event occurred at ECAPx pin.                                      |
| 0    | INT      |       | Global Interrupt Status Flag                                                          |
|      |          | 0     | Indicates no interrupt generated.                                                     |
|      |          | 1     | Indicates that an interrupt was generated.                                            |

# Table 4-10. ECAP Interrupt Flag Register (ECFLG) Field Descriptions

#### Figure 4-20. ECAP Interrupt Clear Register (ECCLR)

| 15      |                |               |                  |       |       |       | 8     |  |  |
|---------|----------------|---------------|------------------|-------|-------|-------|-------|--|--|
|         |                |               | Res              | erved |       |       |       |  |  |
| R-0     |                |               |                  |       |       |       |       |  |  |
| 7       | 6              | 5             | 4                | 3     | 2     | 1     | 0     |  |  |
| CTR=CMP | CTR=PRD        | CTROVF        | CEVT4            | CETV3 | CETV2 | CETV1 | INT   |  |  |
| R/W-0   | R/W-0          | R/W-0         | R/W-0            | R/W-0 | R/W-0 | R/W-0 | R/W-0 |  |  |
|         | Deed/M/sites D | Deed only n y | alua aftar raaat |       |       |       |       |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bits | Field     |   | Description                                                                                                           |  |
|------|-----------|---|-----------------------------------------------------------------------------------------------------------------------|--|
| 15:8 | Reserved  |   | Any writes to these bit(s) must always have a value of 0.                                                             |  |
| 7    | 7 CTR=CMP |   | Counter Equal Compare Status Flag                                                                                     |  |
|      |           | 0 | Writing a 0 has no effect. Always reads back a 0                                                                      |  |
|      |           | 1 | Writing a 1 clears the CTR=CMP flag condition                                                                         |  |
| 6    | 6 CTR=PRD |   | Counter Equal Period Status Flag                                                                                      |  |
|      |           | 0 | Writing a 0 has no effect. Always reads back a 0                                                                      |  |
|      |           | 1 | Writing a 1 clears the CTR=PRD flag condition                                                                         |  |
| 5    | 5 CTROVF  |   | Counter Overflow Status Flag                                                                                          |  |
|      |           | 0 | Writing a 0 has no effect. Always reads back a 0                                                                      |  |
|      |           | 1 | Writing a 1 clears the CTROVF flag condition                                                                          |  |
| 4    | 4 CEVT4   |   | Capture Event 4 Status Flag                                                                                           |  |
|      |           | 0 | Writing a 0 has no effect. Always reads back a 0.                                                                     |  |
|      |           |   | Writing a 1 clears the CEVT4 flag condition.                                                                          |  |
| 3    |           |   | Capture Event 3 Status Flag                                                                                           |  |
|      |           | 0 | Writing a 0 has no effect. Always reads back a 0.                                                                     |  |
|      |           | 1 | Writing a 1 clears the CEVT3 flag condition.                                                                          |  |
| 2    | 2 CEVT2   |   | Capture Event 2 Status Flag                                                                                           |  |
|      |           | 1 | Writing a 0 has no effect. Always reads back a 0.                                                                     |  |
|      |           | 0 | Writing a 1 clears the CEVT2 flag condition.                                                                          |  |
| 1    | 1 CEVT1   |   | Capture Event 1 Status Flag                                                                                           |  |
|      |           | 0 | Writing a 0 has no effect. Always reads back a 0.                                                                     |  |
|      |           | 1 | Writing a 1 clears the CEVT1 flag condition.                                                                          |  |
| 0    | 0 INT     |   | Global Interrupt Clear Flag                                                                                           |  |
|      |           | 0 | Writing a 0 has no effect. Always reads back a 0.                                                                     |  |
|      |           | 1 | Writing a 1 clears the INT flag and enable further interrupts to be generated if any of the event flags are set to 1. |  |

## Table 4-11. ECAP Interrupt Clear Register (ECCLR) Field Descriptions

| Figure 4-21. ECAP | Interrupt Forcing | Register (ECFRC) |
|-------------------|-------------------|------------------|
|-------------------|-------------------|------------------|

| 15                                                           | 14      | 13     | 12    | 11    | 10    | 9     | 8        |
|--------------------------------------------------------------|---------|--------|-------|-------|-------|-------|----------|
| Reserved                                                     |         |        |       |       |       |       |          |
|                                                              | R-0     |        |       |       |       |       |          |
| 7                                                            | 6       | 5      | 4     | 3     | 2     | 1     | 0        |
| CTR=CMP                                                      | CTR=PRD | CTROVF | CEVT4 | CETV3 | CETV2 | CETV1 | reserved |
| R/W-0                                                        | R/W-0   | R/W-0  | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-0      |
| LECEND: DAV. DeadAV/rite: D. Dead only: n. value after react |         |        |       |       |       |       |          |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 4-12. ECAP Interrupt Forcing Register (ECFRC) Field Descriptions

| Bits | Field    | Value | Description                                               |  |
|------|----------|-------|-----------------------------------------------------------|--|
| 15:8 | Reserved | 0     | Any writes to these bit(s) must always have a value of 0. |  |
| 7    | CTR=CMP  |       | Force Counter Equal Compare Interrupt                     |  |
|      |          | 0     | No effect. Always reads back a 0.                         |  |
|      |          | 1     | Writing a 1 sets the CTR=CMP flag bit.                    |  |
| 6    | CTR=PRD  |       | Force Counter Equal Period Interrupt                      |  |
|      |          | 0     | No effect. Always reads back a 0.                         |  |
|      |          | 1     | Writing a 1 sets the CTR=PRD flag bit.                    |  |

| Bits | Field    | Value                 | Description                                               |  |
|------|----------|-----------------------|-----------------------------------------------------------|--|
| 5    | CTROVF   |                       | Force Counter Overflow                                    |  |
|      |          | 0                     | No effect. Always reads back a 0.                         |  |
|      |          | 1                     | Writing a 1 to this bit sets the CTROVF flag bit.         |  |
| 4    | CEVT4    |                       | Force Capture Event 4                                     |  |
|      |          | 0                     | No effect. Always reads back a 0.                         |  |
|      |          | 1                     | Writing a 1 sets the CEVT4 flag bit                       |  |
| 3    | CEVT3    |                       | Force Capture Event 3                                     |  |
|      |          | 0                     | No effect. Always reads back a 0.                         |  |
|      |          | 1                     | Writing a 1 sets the CEVT3 flag bit                       |  |
| 2    | CEVT2    | Force Capture Event 2 |                                                           |  |
|      |          | 0                     | No effect. Always reads back a 0.                         |  |
|      |          | 1                     | Writing a 1 sets the CEVT2 flag bit.                      |  |
| 1    | CEVT1    |                       | Force Capture Event 1                                     |  |
|      |          | 1                     | No effect. Always reads back a 0.                         |  |
|      |          | 0                     | Sets the CEVT1 flag bit.                                  |  |
| 0    | Reserved | 0                     | Any writes to these bit(s) must always have a value of 0. |  |

#### Table 4-12. ECAP Interrupt Forcing Register (ECFRC) Field Descriptions (continued)

#### 4.6 Register Mapping

Table 4-13 shows the eCAP module control and status register set.

| Name                | Offset          | Size (x16) | Description                         |
|---------------------|-----------------|------------|-------------------------------------|
| Time Base Module Re | gisters         |            |                                     |
| TSCTR               | 0x0000          | 2          | Time-Stamp Counter                  |
| CTRPHS              | 0x0002          | 2          | Counter Phase Offset Value Register |
| CAP1                | 0x0004          | 2          | Capture 1 Register                  |
| CAP2                | 0x0006          | 2          | Capture 2 Register                  |
| CAP3                | 0x0008          | 2          | Capture 3 Register                  |
| CAP4                | 0x000A          | 2          | Capture 4 Register                  |
| reserved            | 0x000C - 0x0013 | 8          |                                     |
| ECCTL1              | 0x0014          | 1          | Capture Control Register 1          |
| ECCTL2              | 0x0015          | 1          | Capture Control Register 2          |
| ECEINT              | 0x0016          | 1          | Capture Interrupt Enable Register   |
| ECFLG               | 0x0017          | 1          | Capture Interrupt Flag Register     |
| ECCLR               | 0x0018          | 1          | Capture Interrupt Clear Register    |
| ECFRC               | 0x0019          | 1          | Capture Interrupt Force Register    |
| Reserved            | 0x001A - 0x001F | 6          |                                     |

#### Table 4-13. Control and Status Register Set

# 4.7 Application of the ECAP Module

The following sections will provide Applications examples and code snippets to show how to configure and operate the eCAP module. For clarity and ease of use, the examples use the eCAP "C" header files. Below are useful #defines which will help in the understanding of the examples.

// ECCTL1 ( ECAP Control Reg 1)
//=========

// CAPxPOL bits #define EC\_RISING 0x0
#define EC\_FALLING 0x1

Texas Instruments

www.ti.com

// CTRRSTx bits #define EC\_ABS\_MODE 0x0 #define EC\_DELTA\_MODE 0x1 // PRESCALE bits #define EC BYPASS 0x0 #define EC\_DIV1 0x0 #define EC\_DIV2 0x1 #define EC\_DIV4 0x2 #define EC\_DIV6 0x3 #define EC\_DIV8 0x4 #define EC\_DIV10 0x5 // ECCTL2 ( ECAP Control Reg 2) // CONT/ONESHOT bit #define EC\_CONTINUOUS 0x0 #define EC\_ONESHOT 0x1 // STOPVALUE bit #define EC\_EVENT1 0x0 #define EC\_EVENT2 0x1 #define EC\_EVENT3 0x2 #define EC\_EVENT4 0x3 // RE-ARM bit #define EC\_ARM 0x1 // TSCTRSTOP bit #define EC\_FREEZE 0x0 #define EC\_RUN 0x1 // SYNCO\_SEL bit #define EC\_SYNCIN 0x0 #define EC\_CTR\_PRD 0x1 #define EC\_SYNCO\_DIS 0x2 // CAP/APWM mode bit #define EC\_CAP\_MODE 0x0 #define EC\_APWM\_MODE 0x1 // APWMPOL bit #define EC\_ACTV\_HI 0x0 #define EC\_ACTV\_LO 0x1 // Generic #define EC\_DISABLE 0x0 #define EC\_ENABLE 0x1 #define EC\_FORCE 0x1

# 4.7.1 Example 1 - Absolute Time-Stamp Operation Rising Edge Trigger

Figure 4-22 shows an example of continuous capture operation (Mod4 counter wraps around). In this figure, TSCTR counts-up without resetting and capture events are qualified on the rising edge only, this gives period (and frequency) information.

On an event, the TSCTR contents (time-stamp) is first captured, then Mod4 counter is incremented to the next state. When the TSCTR reaches FFFFFFF (maximum value), it wraps around to 00000000 (not shown in Figure 4-22), if this occurs, the CTROVF (counter overflow) flag is set, and an interrupt (if enabled) occurs, CTROVF (counter overflow) Flag is set, and an Interrupt (if enabled) occurs. Captured Time-stamps are valid at the point indicated by the diagram, that is, after the 4th event, hence event CEVT4 can conveniently be used to trigger an interrupt and the CPU can read data from the CAPx registers.



Figure 4-22. Capture Sequence for Absolute Time-stamp and Rising Edge Detect



#### Application of the ECAP Module

www.ti.com

## 4.7.1.1 Code Snippet for CAP Mode Absolute Time, Rising Edge Trigger

// Code snippet for CAP mode Absolute Time, Rising edge trigger

```
// Initialization Time
// ECAP module 1 config
ECap1Regs.ECCTL1.bit.CAP1POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP2POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP3POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP4POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CTRRST1 = EC_ABS_MODE;
ECap1Regs.ECCTL1.bit.CTRRST2 = EC_ABS_MODE;
ECap1Regs.ECCTL1.bit.CTRRST3 = EC_ABS_MODE;
ECap1Regs.ECCTL1.bit.CTRRST4 = EC_ABS_MODE;
ECap1Regs.ECCTL1.bit.CAPLDEN = EC_ENABLE;
ECap1Regs.ECCTL1.bit.PRESCALE = EC_DIV1;
ECap1Regs.ECCTL2.bit.CAP_APWM = EC_CAP_MODE;
ECap1Regs.ECCTL2.bit.CONT_ONESHT = EC_CONTINUOUS;
ECap1Regs.ECCTL2.bit.SYNCO_SEL = EC_SYNCO_DIS;
ECap1Regs.ECCTL2.bit.SYNCI_EN = EC_DISABLE;
ECap1Regs.ECCTL2.bit.TSCTRSTOP = EC_RUN; // Allow TSCTR to run
// Run Time ( for example, CEVT4 triggered ISR call)
TSt1 = ECaplRegs.CAP1; // Fetch Time-Stamp captured at t1
TSt2 = ECaplRegs.CAP2; // Fetch Time-Stamp captured at t2
TSt3 = ECaplRegs.CAP3; // Fetch Time-Stamp captured at t3
TSt4 = ECaplRegs.CAP4; // Fetch Time-Stamp captured at t4
Period1 = TSt2 - TSt1; // Calculate 1st period
Period2 = TSt3-TSt2; // Calculate 2nd period
```

Period3 = TSt4 - TSt3; // Calculate 3rd period

Application of the ECAP Module

# 4.7.2 Example 2 - Absolute Time-Stamp Operation Rising and Falling Edge Trigger

In Figure 4-23 the eCAP operating mode is almost the same as in the previous section except capture events are qualified as either rising or falling edge, this now gives both period and duty cycle information, i.e: Period1 =  $t_3 - t_1$ , Period2 =  $t_5 - t_3$ , ...etc. Duty Cycle1 (on-time %) =  $(t_2 - t_1)$  / Period1 x 100%, etc. Duty Cycle1 (off-time %) =  $(t_3 - t_2)$  / Period1 x 100%, etc.







#### Application of the ECAP Module

www.ti.com

## 4.7.2.1 Code Snippet for CAP Mode Absolute Time, Rising and Falling Edge Triggers

// Code snippet for CAP mode Absolute Time, Rising and Falling // edge triggers

```
// Initialization Time
// ECAP module 1 config
ECap1Regs.ECCTL1.bit.CAP1POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP2POL = EC_FALLING;
ECap1Regs.ECCTL1.bit.CAP3POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP4POL = EC_FALLING;
ECap1Regs.ECCTL1.bit.CTRRST1 = EC_ABS_MODE;
ECap1Regs.ECCTL1.bit.CTRRST2 = EC_ABS_MODE;
ECap1Regs.ECCTL1.bit.CTRRST3 = EC_ABS_MODE;
ECap1Regs.ECCTL1.bit.CTRRST4 = EC_ABS_MODE;
ECap1Regs.ECCTL1.bit.CAPLDEN = EC_ENABLE;
ECap1Regs.ECCTL1.bit.PRESCALE = EC_DIV1;
ECap1Regs.ECCTL2.bit.CAP_APWM = EC_CAP_MODE;
ECap1Regs.ECCTL2.bit.CONT_ONESHT = EC_CONTINUOUS;
ECap1Regs.ECCTL2.bit.SYNCO_SEL = EC_SYNCO_DIS;
ECap1Regs.ECCTL2.bit.SYNCI_EN = EC_DISABLE;
ECap1Regs.ECCTL2.bit.TSCTRSTOP = EC_RUN; // Allow TSCTR to run
// Run Time ( for example, CEVT4 triggered ISR call)
//-----
TSt1 = ECaplRegs.CAP1; // Fetch Time-Stamp captured at t1
TSt2 = ECaplRegs.CAP2; // Fetch Time-Stamp captured at t2
TSt3 = ECaplRegs.CAP3; // Fetch Time-Stamp captured at t3
TSt4 = ECaplRegs.CAP4; // Fetch Time-Stamp captured at t4
Period1 = TSt3-TSt1; // Calculate 1st period
DutyOnTime1 = TSt2-TSt1; // Calculate On time
DutyOffTime1 = TSt3-TSt2; // Calculate Off time
```



# 4.7.3 Example 3 - Time Difference (Delta) Operation Rising Edge Trigger

This example Figure 4-24 shows how the eCAP module can be used to collect Delta timing data from pulse train waveforms. Here Continuous Capture mode (TSCTR counts-up without resetting, and Mod4 counter wraps around) is used. In Delta-time mode, TSCTR is Reset back to Zero on every valid event. Here Capture events are qualified as Rising edge only. On an event, TSCTR contents (time-stamp) is captured first, and then TSCTR is reset to Zero. The Mod4 counter then increments to the next state. If TSCTR reaches FFFFFFF (Max value), before the next event, it wraps around to 00000000 and continues, a CNTOVF (counter overflow) Flag is set, and an Interrupt (if enabled) occurs. The advantage of Delta-time Mode is that the CAPx contents directly give timing data without the need for CPU calculations, that is, Period1 =  $T_1$ , Period2 =  $T_2$ ,...etc. As shown in the diagram, the CEVT1 event is a good trigger point to read the timing data,  $T_1$ ,  $T_2$ ,  $T_3$ ,  $T_4$  are all valid here.



Figure 4-24. Capture Sequence for Delta Mode Time-stamp and Rising Edge Detect



#### Application of the ECAP Module

www.ti.com

#### 4.7.3.1 Code Snippet for CAP Mode Delta Time, Rising Edge Trigger

// Code snippet for CAP mode Delta Time, Rising edge trigger

```
// Initialization Time
// ECAP module 1 config
ECap1Regs.ECCTL1.bit.CAP1POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP2POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP3POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP4POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CTRRST1 = EC_DELTA_MODE;
ECap1Regs.ECCTL1.bit.CTRRST2 = EC_DELTA_MODE;
ECap1Regs.ECCTL1.bit.CTRRST3 = EC_DELTA_MODE;
ECaplRegs.ECCTL1.bit.CTRRST4 = EC_DELTA_MODE;
ECap1Regs.ECCTL1.bit.CAPLDEN = EC_ENABLE;
ECap1Regs.ECCTL1.bit.PRESCALE = EC_DIV1;
ECap1Regs.ECCTL2.bit.CAP_APWM = EC_CAP_MODE;
ECap1Regs.ECCTL2.bit.CONT_ONESHT = EC_CONTINUOUS;
ECap1Regs.ECCTL2.bit.SYNCO_SEL = EC_SYNCO_DIS;
ECap1Regs.ECCTL2.bit.SYNCI_EN = EC_DISABLE;
ECap1Regs.ECCTL2.bit.TSCTRSTOP = EC_RUN; // AllowvTSCTR to run
// Run Time (for example, CEVT1 triggered ISR call)
// Note: here Time-stamp directly represents the Period value.
Period4 = ECap1Regs.CAP1; // Fetch Time-Stamp captured at T1
Period1 = ECap1Regs.CAP2; // Fetch Time-Stamp captured at T2
```

Period2 = ECaplRegs.CAP3; // Fetch Time-Stamp captured at T3
Period3 = ECaplRegs.CAP4; // Fetch Time-Stamp captured at T4

Application of the ECAP Module

# 4.7.4 Example 4 - Time Difference (Delta) Operation Rising and Falling Edge Trigger

In Figure 4-25 the eCAP operating mode is almost the same as in previous section except Capture events are qualified as either Rising or Falling edge, this now gives both Period and Duty cycle information, i.e. Period1 =  $T_1+T_2$ , Period2 =  $T_3+T_4$ , ...etc Duty Cycle1 (on-time %) =  $T_1$  / Period1 x 100%, etc Duty Cycle1 (off-time %) =  $T_2$  / Period1 x 100%, etc



## Figure 4-25. Capture Sequence for Delta Mode Time-stamp With Rising and Falling Edge Detect

During initialization, you must write to the active registers for both period and compare. This will then automatically copy the init values into the shadow values. For subsequent compare updates, that is, during run-time, only the shadow registers must be used.



#### Application of the ECAP Module

www.ti.com

## 4.7.4.1 Code snippet for CAP Mode Delta Time, Rising and Falling Edge Triggers

```
// Code snippet for CAP mode Delta Time, Rising and Falling
// edge triggers
```

```
// Initialization Time
// ECAP module 1 config ECaplRegs.ECCTL1.bit.CAP1POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP2POL = EC_FALLING;
ECap1Regs.ECCTL1.bit.CAP3POL = EC_RISING;
ECap1Regs.ECCTL1.bit.CAP4POL = EC_FALLING;
ECap1Regs.ECCTL1.bit.CTRRST1 = EC_DELTA_MODE;
ECap1Regs.ECCTL1.bit.CTRRST2 = EC_DELTA_MODE;
ECap1Regs.ECCTL1.bit.CTRRST3 = EC_DELTA_MODE;
ECaplRegs.ECCTL1.bit.CTRRST4 = EC_DELTA_MODE;
ECap1Regs.ECCTL1.bit.CAPLDEN = EC_ENABLE;
ECap1Regs.ECCTL1.bit.PRESCALE = EC_DIV1;
ECap1Regs.ECCTL2.bit.CAP_APWM = EC_CAP_MODE;
ECap1Regs.ECCTL2.bit.CONT_ONESHT = EC_CONTINUOUS;
ECap1Regs.ECCTL2.bit.SYNCO_SEL = EC_SYNCO_DIS;
ECap1Regs.ECCTL2.bit.SYNCI_EN = EC_DISABLE;
ECaplRegs.ECCTL2.bit.TSCTRSTOP = EC_RUN; // Allow SCTR to run
// Run Time (for example, CEVT1 triggered ISR call)
// Note: here Time-stamp directly represents the Duty cycle values.
```

```
DutyOnTime1 = ECaplRegs.CAP2; // Fetch Time-Stamp captured at T2
DutyOffTime1 = ECaplRegs.CAP3; // Fetch Time-Stamp captured at T3
DutyOnTime2 = ECaplRegs.CAP4; // Fetch Time-Stamp captured at T4
DutyOffTime2 = ECaplRegs.CAP1; // Fetch Time-Stamp captured at T1
Period1 = DutyOnTime1 + DutyOffTime1;
Period2 = DutyOnTime2 + DutyOffTime2;
```

## 4.8 Application of the APWM Mode

In this example, the eCAP module is configured to operate as a PWM generator. Here a very simple single channel PWM waveform is generated from output pin APWMx. The PWM polarity is active high, which means that the compare value (CAP2 reg is now a compare register) represents the on-time (high level) of the period. Alternatively, if the APWMPOL bit is configured for active low, then the compare value represents the off-time. Note here values are in hexadecimal ("h") notation.

# 4.8.1 Example 1 - Simple PWM Generation (Independent Channel/s)



## Figure 4-26. PWM Waveform Details of APWM Mode Operation

Example 4-1. Code Snippet for APWM Mode

```
// Code snippet for APWM mode Example 1
// Initialization Time
// ECAP module 1 config
ECaplRegs.CAP1 = 0x1000; // Set period value
ECaplRegs.CTRPHS = 0x0; // make phase zero
ECap1Regs.ECCTL2.bit.CAP_APWM = EC_APWM_MODE;
ECap1Regs.ECCTL2.bit.APWMPOL = EC_ACTV_HI; //Active high
ECaplRegs.ECCTL2.bit.SYNCI_EN = EC_DISABLE; // Synch not used
ECap1Regs.ECCTL2.bit.SYNCO_SEL = EC_SYNCO_DIS; // Synch not used
ECap1Regs.ECCTL2.bit.TSCTRSTOP = EC_RUN; // Allow TSCTR to run
// Run Time (Instant 1, for example, ISR call)
ECap1Regs.CAP2 = 0x300;
// Set Duty cycle (compare value)
// Run Time (Instant 2, for example, another ISR call)
ECap1Regs.CAP2 = 0x500;
```



Application of the APWM Mode

www.ti.com

# Example 4-1. Code Snippet for APWM Mode (continued)

// Set Duty cycle (compare value)



# Enhanced QEP (eQEP) Module

The enhanced quadrature encoder pulse (eQEP) module is used for direct interface with a linear or rotary incremental encoder to get position, direction, and speed information from a rotating machine for use in a high-performance motion and position-control system.

| Горіс |                                          | Page       |
|-------|------------------------------------------|------------|
|       |                                          |            |
| 5.1   | Introduction                             | 408        |
| 5.2   | Description                              | <b>410</b> |
| 5.3   | Quadrature Decoder Unit (QDU)            | 413        |
| 5.4   | Position Counter and Control Unit (PCCU) | 416        |
| 5.5   | eQEP Edge Capture Unit                   | 423        |
| 5.6   | eQEP Watchdog                            | <b>426</b> |
| 5.7   | Unit Timer Base                          | <b>426</b> |
| 5.8   | eQEP Interrupt Structure                 | 427        |
| 5.9   | eQEP Registers                           | 427        |
|       |                                          |            |

## 5.1 Introduction

A single track of slots patterns the periphery of an incremental encoder disk, as shown in Figure 5-1. These slots create an alternating pattern of dark and light lines. The disk count is defined as the number of dark/light line pairs that occur per revolution (lines per revolution). As a rule, a second track is added to generate a signal that occurs once per revolution (index signal: QEPI), which can be used to indicate an absolute position. Encoder manufacturers identify the index pulse using different terms such as index, marker, home position, and zero reference





To derive direction information, the lines on the disk are read out by two different photo-elements that "look" at the disk pattern with a mechanical shift of 1/4 the pitch of a line pair between them. This shift is realized with a reticle or mask that restricts the view of the photo-element to the desired part of the disk lines. As the disk rotates, the two photo-elements generate signals that are shifted 90° out of phase from each other. These are commonly called the quadrature QEPA and QEPB signals. The clockwise direction for most encoders is defined as the QEPA channel going positive before the QEPB channel and vise versa as shown in Figure 5-2.





Legend: N = lines per revolution

The encoder wheel typically makes one revolution for every revolution of the motor or the wheel may be at a geared rotation ratio with respect to the motor. Therefore, the frequency of the digital signal coming from the QEPA and QEPB outputs varies proportionally with the velocity of the motor. For example, a 2000-line encoder directly coupled to a motor running at 5000 revolutions per minute (rpm) results in a frequency of 166.6 KHz, so by measuring the frequency of either the QEPA or QEPB output, the processor can determine the velocity of the motor.



Quadrature encoders from different manufacturers come with two forms of index pulse (gated index pulse or ungated index pulse) as shown in Figure 5-3. A nonstandard form of index pulse is ungated. In the ungated configuration, the index edges are not necessarily coincident with A and B signals. The gated index pulse is aligned to any of the four quadrature edges and width of the index pulse and can be equal to a quarter, half, or full period of the quadrature signal.



Figure 5-3. Index Pulse Example

Some typical applications of shaft encoders include robotics and even computer input in the form of a mouse. Inside your mouse you can see where the mouse ball spins a pair of axles (a left/right, and an up/down axle). These axles are connected to optical shaft encoders that effectively tell the computer how fast and in what direction the mouse is moving.

**General Issues:** Estimating velocity from a digital position sensor is a cost-effective strategy in motor control. Two different first order approximations for velocity may be written as:

$$v(k) \approx \frac{x(k) - x(k-1)}{T} = \frac{\Delta X}{T}$$

$$v(k) \approx \frac{X}{t(k) - t(k-1)} = \frac{X}{\Delta T}$$
(1)
(2)

where

v(k): Velocity at time instant k

x(k): Position at time instant k

x(k-1): Position at time instant k-1

T: Fixed unit time or inverse of velocity calculation rate

ΔX: Incremental position movement in unit time

t(k): Time instant "k"

t(k-1): Time instant "k-1"

X: Fixed unit position

 $\Delta T$ : Incremental time elapsed for unit position movement.

Equation 1 is the conventional approach to velocity estimation and it requires a time base to provide unit time event for velocity calculation. Unit time is basically the inverse of the velocity calculation rate.



The encoder count (position) is read once during each unit time event. The quantity [x(k) - x(k-1)] is formed by subtracting the previous reading from the current reading. Then the velocity estimate is computed by multiplying by the known constant 1/T (where T is the constant time between unit time events and is known in advance).

Estimation based on Equation 1 has an inherent accuracy limit directly related to the resolution of the position sensor and the unit time period T. For example, consider a 500-line per revolution quadrature encoder with a velocity calculation rate of 400 Hz. When used for position the quadrature encoder gives a four-fold increase in resolution, in this case, 2000 counts per revolution. The minimum rotation that can be detected is therefore 0.0005 revolutions, which gives a velocity resolution of 12 rpm when sampled at 400 Hz. While this resolution may be satisfactory at moderate or high speeds, e.g. 1% error at 1200 rpm, it would clearly prove inadequate at low speeds. In fact, at speeds below 12 rpm, the speed estimate would erroneously be zero much of the time.

At low speed, Equation 2 provides a more accurate approach. It requires a position sensor that outputs a fixed interval pulse train, such as the aforementioned quadrature encoder. The width of each pulse is defined by motor speed for a given sensor resolution. Equation 2 can be used to calculate motor speed by measuring the elapsed time between successive quadrature pulse edges. However, this method suffers from the opposite limitation, as does Equation 1. A combination of relatively large motor speeds and high sensor resolution makes the time interval  $\Delta T$  small, and thus more greatly influenced by the timer resolution. This can introduce considerable error into high-speed estimates.

For systems with a large speed range (that is, speed estimation is needed at both low and high speeds), one approach is to use Equation 2 at low speed and have the DSP software switch over to Equation 1 when the motor speed rises above some specified threshold.

## 5.2 Description

This section provides the eQEP inputs, memory map, and functional description.

## 5.2.1 EQEP Inputs

The eQEP inputs include two pins for quadrature-clock mode or direction-count mode, an index (or 0 marker), and a strobe input. The eQEP module requires that the QEPA, QEPB, and QEPI inputs are synchronized to SYSCLK prior to entering the module. The application code should enable the synchronous GPIO input feature on any eQEP-enabled GPIO pins (See the *System Control and Interrupts* user guide for your device for more details).

QEPA/XCLK and QEPB/XDIR

These two pins can be used in quadrature-clock mode or direction-count mode.

- Quadrature-clock Mode

The eQEP encoders provide two square wave signals (A and B) 90 electrical degrees out of phase whose phase relationship is used to determine the direction of rotation of the input shaft and number of eQEP pulses from the index position to derive the relative position information. For forward or clockwise rotation, QEPA signal leads QEPB signal and vice versa. The quadrature decoder uses these two inputs to generate quadrature-clock and direction signals.

- Direction-count Mode

In direction-count mode, direction and clock signals are provided directly from the external source. Some position encoders have this type of output instead of quadrature output. The QEPA pin provides the clock input and the QEPB pin provides the direction input.

• QEPI: Index or Zero Marker

The eQEP encoder uses an index signal to assign an absolute start position from which position information is incrementally encoded using quadrature pulses. This pin is connected to the index output of the eQEP encoder to optionally reset the position counter for each revolution. This signal can be used to initialize or latch the position counter on the occurrence of a desired event on the index pin.

• QEPS: Strobe Input

This general-purpose strobe signal can initialize or latch the position counter on the occurrence of a desired event on the strobe pin. This signal is typically connected to a sensor or limit switch to notify that the motor has reached a defined position.



# 5.2.2 Functional Description

The eQEP peripheral contains the following major functional units (as shown in Figure 5-4):

- Programmable input qualification for each pin (part of the GPIO MUX)
- Quadrature decoder unit (QDU)
- Position counter and control unit for position measurement (PCCU)
- Quadrature edge-capture unit for low-speed measurement (QCAP)
- Unit time base for speed/frequency measurement (UTIME)
- Watchdog timer for detecting stalls (QWDOG)

## Figure 5-4. Functional Block Diagram of the eQEP Peripheral



Description

## 5.2.3 eQEP Memory Map

Table 5-1 lists the registers with their memory locations, sizes, and reset values.

| Table 5-1. EQEP | Memory Map |  |
|-----------------|------------|--|
|-----------------|------------|--|

| Name     | Offset             | Size(x16)/<br>#shadow | Reset      | Register Description                   |
|----------|--------------------|-----------------------|------------|----------------------------------------|
| QPOSCNT  | 0x00               | 2/0                   | 0x00000000 | eQEP Position Counter                  |
| QPOSINIT | 0x02               | 2/0                   | 0x00000000 | eQEP Initialization Position Count     |
| QPOSMAX  | 0x04               | 2/0                   | 0x00000000 | eQEP Maximum Position Count            |
| QPOSCMP  | 0x06               | 2/1                   | 0x0000000  | eQEP Position-compare                  |
| QPOSILAT | 0x08               | 2/0                   | 0x00000000 | eQEP Index Position Latch              |
| QPOSSLAT | 0x0A               | 2/0                   | 0x00000000 | eQEP Strobe Position Latch             |
| QPOSLAT  | 0x0C               | 2/0                   | 0x00000000 | eQEP Position Latch                    |
| QUTMR    | 0x0E               | 2/0                   | 0x0000000  | QEP Unit Timer                         |
| QUPRD    | 0x10               | 2/0                   | 0x00000000 | eQEP Unit Period Register              |
| QWDTMR   | 0x12               | 1/0                   | 0x0000     | eQEP Watchdog Timer                    |
| QWDPRD   | 0x13               | 1/0                   | 0x0000     | eQEP Watchdog Period Register          |
| QDECCTL  | 0x14               | 1/0                   | 0x0000     | eQEP Decoder Control Register          |
| QEPCTL   | 0x15               | 1/0                   | 0x0000     | eQEP Control Register                  |
| QCAPCTL  | 0x16               | 1/0                   | 0x0000     | eQEP Capture Control Register          |
| QPOSCTL  | 0x17               | 1/0                   | 0x00000    | eQEP Position-compare Control Register |
| QEINT    | 0x18               | 1/0                   | 0x0000     | eQEP Interrupt Enable Register         |
| QFLG     | 0x19               | 1/0                   | 0x0000     | eQEP Interrupt Flag Register           |
| QCLR     | 0x1A               | 1/0                   | 0x0000     | eQEP Interrupt Clear Register          |
| QFRC     | 0x1B               | 1/0                   | 0x0000     | eQEP Interrupt Force Register          |
| QEPSTS   | 0x1C               | 1/0                   | 0x0000     | eQEP Status Register                   |
| QCTMR    | 0x1D               | 1/0                   | 0x0000     | eQEP Capture Timer                     |
| QCPRD    | 0x1E               | 1/0                   | 0x0000     | eQEP Capture Period Register           |
| QCTMRLAT | 0x1F               | 1/0                   | 0x0000     | eQEP Capture Timer Latch               |
| QCPRDLAT | 0x20               | 1/0                   | 0x0000     | eQEP Capture Period Latch              |
| reserved | 0x21<br>to<br>0x3F | 31/0                  |            |                                        |



## 5.3 Quadrature Decoder Unit (QDU)

Figure 5-5 shows a functional block diagram of the QDU.



#### Figure 5-5. Functional Block Diagram of Decoder Unit

## 5.3.1 Position Counter Input Modes

Clock and direction input to position counter is selected using QDECCTL[QSRC] bits, based on interface input requirement as follows:

- Quadrature-count mode
- Direction-count mode
- UP-count mode
- DOWN-count mode



#### 5.3.1.1 Quadrature Count Mode

The quadrature decoder generates the direction and clock to the position counter in quadrature count mode.

**Direction Decoding**— The direction decoding logic of the eQEP circuit determines which one of the sequences (QEPA, QEPB) is the leading sequence and accordingly updates the direction information in QEPSTS[QDF] bit. Table 5-2 and Figure 5-6 show the direction decoding logic in truth table and state machine form. Both edges of the QEPA and QEPB signals are sensed to generate count pulses for the position counter. Therefore, the frequency of the clock generated by the eQEP logic is four times that of each input sequence. Figure 5-7 shows the direction decoding and clock generation from the eQEP input signals.

| Previous Edge | Present Edge | QDIR   | QPOSCNT                |
|---------------|--------------|--------|------------------------|
| QA↑           | QB↑          | UP     | Increment              |
|               | QB↓          | DOWN   | Decrement              |
|               | QA↓          | TOGGLE | Increment or Decremer  |
| QA↓           | QB↓          | UP     | Increment              |
|               | QB↑          | DOWN   | Decrement              |
|               | QA↑          | TOGGLE | Increment or Decrement |
| QB↑           | QA↑          | DOWN   | Increment              |
|               | QA↓          | UP     | Decrement              |
|               | QB↓          | TOGGLE | Increment or Decrement |
| QB↓           | QA↓          | DOWN   | Increment              |
|               | QA↑          | UP     | Decrement              |
|               | QB↑          | TOGGLE | Increment or Decrement |

| Table 5-2 | Quadrature | Decoder | Truth | Table |
|-----------|------------|---------|-------|-------|
|           | Quadrature | Decouci | IIGUI | Iabic |









Figure 5-7. Quadrature-clock and Direction Decoding

- **Phase Error Flag** In normal operating conditions, quadrature inputs QEPA and QEPB will be 90 degrees out of phase. The phase error flag (PHE) is set in the QFLG register when edge transition is detected simultaneously on the QEPA and QEPB signals to optionally generate interrupts. State transitions marked by dashed lines in Figure 5-6 are invalid transitions that generate a phase error.
- **Count Multiplication** The eQEP position counter provides 4x times the resolution of an input clock by generating a quadrature-clock (QCLK) on the rising/falling edges of both eQEP input clocks (QEPA and QEPB) as shown in Figure 5-7.
- **Reverse Count** In normal quadrature count operation, QEPA input is fed to the QA input of the quadrature decoder and the QEPB input is fed to the QB input of the quadrature decoder. Reverse counting is enabled by setting the SWAP bit in the QDECCTL register. This will swap the input to the quadrature decoder thereby reversing the counting direction.

## 5.3.1.2 Direction-Count Mode

Some position encoders provide direction and clock outputs, instead of quadrature outputs. In such cases, direction-count mode can be used. QEPA input will provide the clock for position counter and the QEPB input will have the direction information. The position counter is incremented on every rising edge of a QEPA input when the direction input is high and decremented when the direction input is low.

## 5.3.1.3 Up-Count Mode

The counter direction signal is hard-wired for up count and the position counter is used to measure the frequency of the QEPA input. Clearing the QDECCTL[XCR] bit enables clock generation to the position counter on both edges of the QEPA input, thereby increasing the measurement resolution by 2x factor. In up-count mode, it is recommended that the application not configure QEPB as a GPIO mux option, or ensure that a signal edge is not generated on the QEPB input.



#### 5.3.1.4 Down-Count Mode

The counter direction signal is hardwired for a down count and the position counter is used to measure the frequency of the QEPA input. Setting of the QDECCTL[XCR] bit enables clock generation to the position counter on both edges of a QEPA input, thereby increasing the measurement resolution by 2x factor. In down-count mode, it is recommended that the application not configure QEPB as a GPIO mux option, or ensure that a signal edge is not generated on the QEPB input.

## 5.3.2 eQEP Input Polarity Selection

Each eQEP input can be inverted using QDECCTL[8:5] control bits. As an example, setting of QDECCTL[QIP] bit will invert the index input.

## 5.3.3 Position-Compare Sync Output

The enhanced eQEP peripheral includes a position-compare unit that is used to generate the positioncompare sync signal on compare match between the position counter register (QPOSCNT) and the position-compare register (QPOSCMP). This sync signal can be output using an index pin or strobe pin of the EQEP peripheral.

Setting the QDECCTL[SOEN] bit enables the position-compare sync output and the QDECCTL[SPSEL] bit selects either an eQEP index pin or an eQEP strobe pin.

## 5.4 Position Counter and Control Unit (PCCU)

The position counter and control unit provides two configuration registers (QEPCTL and QPOSCTL) for setting up position counter operational modes, position counter initialization/latch modes and position-compare logic for sync signal generation.

## 5.4.1 Position Counter Operating Modes

Position counter data may be captured in different manners. In some systems, the position counter is accumulated continuously for multiple revolutions and the position counter value provides the position information with respect to the known reference. An example of this is the quadrature encoder mounted on the motor controlling the print head in the printer. Here the position counter is reset by moving the print head to the home position and then position counter provides absolute position information with respect to home position.

In other systems, the position counter is reset on every revolution using index pulse and position counter provides rotor angle with respect to index pulse position.

Position counter can be configured to operate in following four modes

- Position Counter Reset on Index Event
- Position Counter Reset on Maximum Position
- Position Counter Reset on the first Index Event
- Position Counter Reset on Unit Time Out Event (Frequency Measurement)

In all the above operating modes, position counter is reset to 0 on overflow and to QPOSMAX register value on underflow. Overflow occurs when the position counter counts up after QPOSMAX value. Underflow occurs when position counter counts down after "0". Interrupt flag is set to indicate overflow/underflow in QFLG register.

## 5.4.1.1 Position Counter Reset on Index Event (QEPCTL[PCRM]=00)

If the index event occurs during the forward movement, then position counter is reset to 0 on the next eQEP clock. If the index event occurs during the reverse movement, then the position counter is reset to the value in the QPOSMAX register on the next eQEP clock.

First index marker is defined as the quadrature edge following the first index edge. The eQEP peripheral records the occurrence of the first index marker (QEPSTS[FIMF]) and direction on the first index event marker (QEPSTS[FIDF]) in QEPSTS registers, it also remembers the quadrature edge on the first index marker so that same relative quadrature transition is used for index event reset operation.



For example, if the first reset operation occurs on the falling edge of QEPB during the forward direction, then all the subsequent reset must be aligned with the falling edge of QEPB for the forward rotation and on the rising edge of QEPB for the reverse rotation as shown in Figure 5-8.

The position-counter value is latched to the QPOSILAT register and direction information is recorded in the QEPSTS[QDLF] bit on every index event marker. The position-counter error flag (QEPSTS[PCEF]) and error interrupt flag (QFLG[PCE]) are set if the latched value is not equal to 0 or QPOSMAX. The position-counter error flag (QEPSTS[PCEF]) is updated on every index event marker and an interrupt flag (QFLG[PCE]) will be set on error that can be cleared only through software.

The index event latch configuration QEPCTL[IEL] bits are ignored in this mode and position counter error flag/interrupt flag are generated only in index event reset mode.



Figure 5-8. Position Counter Reset by Index Pulse for 1000 Line Encoder (QPOSMAX = 3999 or 0xF9F)

## 5.4.1.2 Position Counter Reset on Maximum Position (QEPCTL[PCRM]=01)

If the position counter is equal to QPOSMAX, then the position counter is reset to 0 on the next eQEP clock for forward movement and position counter overflow flag is set. If the position counter is equal to ZERO, then the position counter is reset to QPOSMAX on the next QEP clock for reverse movement and position counter underflow flag is set. Figure 5-9 shows the position counter reset operation in this mode.

First index marker is defined as the quadrature edge following the first index edge. The eQEP peripheral records the occurrence of the first index marker (QEPSTS[FIMF]) and direction on the first index event marker (QEPSTS[FIDF]) in the QEPSTS registers; it also remembers the quadrature edge on the first index marker so that the same relative quadrature transition is used for the software index marker (QEPCTL[IEL]=11).



## 5.4.1.3 Position Counter Reset on the First Index Event (QEPCTL[PCRM] = 10)

If the index event occurs during forward movement, then the position counter is reset to 0 on the next eQEP clock. If the index event occurs during the reverse movement, then the position counter is reset to the value in the QPOSMAX register on the next eQEP clock. Note that this is done only on the first occurrence and subsequently the position counter value is not reset on an index event; rather, it is reset based on maximum position as described in Section 5.4.1.2.

First index marker is defined as the quadrature edge following the first index edge. The eQEP peripheral records the occurrence of the first index marker (QEPSTS[FIMF]) and direction on the first index event marker (QEPSTS[FIDF]) in QEPSTS registers, it also remembers the quadrature edge on the first index marker so that same relative quadrature transition is used for software index marker (QEPCTL[IEL]=11).

## 5.4.1.4 Position Counter Reset on Unit Time out Event (QEPCTL[PCRM] = 11)

In this mode, the QPOSCNT value is latched to the QPOSLAT register and then the QPOSCNT is reset (to 0 or QPOSMAX, depending on the direction mode selected by QDECCTL[QSRC] bits on a unit time event). This is useful for frequency measurement.

## 5.4.2 Position Counter Latch

The eQEP index and strobe input can be configured to latch the position counter (QPOSCNT) into QPOSILAT and QPOSSLAT, respectively, on occurrence of a definite event on these pins.

#### 5.4.2.1 Index Event Latch

In some applications, it may not be desirable to reset the position counter on every index event and instead it may be required to operate the position counter in full 32-bit mode (QEPCTL[PCRM] = 01 and QEPCTL[PCRM] = 10 modes).

In such cases, the eQEP position counter can be configured to latch on the following events and direction information is recorded in the QEPSTS[QDLF] bit on every index event marker.

- Latch on Rising edge (QEPCTL[IEL]=01)
- Latch on Falling edge (QEPCTL[IEL]=10)
- Latch on Index Event Marker (QEPCTL[IEL]=11)

This is particularly useful as an error checking mechanism to check if the position counter accumulated the correct number of counts between index events. As an example, the 1000-line encoder must count 4000 times when moving in the same direction between the index events.

The index event latch interrupt flag (QFLG[IEL]) is set when the position counter is latched to the QPOSILAT register.

- Latch on Rising Edge (QEPCTL[IEL]=01)— The position counter value (QPOSCNT) is latched to the QPOSILAT register on every rising edge of an index input.
- Latch on Falling Edge (QEPCTL[IEL] = 10)— The position counter value (QPOSCNT) is latched to the QPOSILAT register on every falling edge of index input.
- Latch on Index Event Marker/Software Index Marker (QEPCTL[IEL] = 11— The first index marker is defined as the quadrature edge following the first index edge. The eQEP peripheral records the occurrence of the first index marker (QEPSTS[FIMF]) and direction on the first index event marker (QEPSTS[FIDF]) in the QEPSTS registers. It also remembers the quadrature edge on the first index marker so that same relative quadrature transition is used for latching the position counter (QEPCTL[IEL]=11).

Figure 5-10 shows the position counter latch using an index event marker.



# Figure 5-10. Software Index Marker for 1000-line Encoder (QEPCTL[IEL] = 1)

## 5.4.2.2 Strobe Event Latch

The position-counter value is latched to the QPOSSLAT register on the rising edge of the strobe input by clearing the QEPCTL[SEL] bit.

If the QEPCTL[SEL] bit is set, then the position counter value is latched to the QPOSSLAT register on the rising edge of the strobe input for forward direction and on the falling edge of the strobe input for reverse direction as shown in Figure 5-11.

The strobe event latch interrupt flag (QFLG[SEL) is set when the position counter is latched to the QPOSSLAT register.



Figure 5-11. Strobe Event Latch (QEPCTL[SEL] = 1)

## 5.4.3 Position Counter Initialization

The position counter can be initialized using following events:

- Index event
- Strobe event
- Software initialization
- Index Event Initialization (IEI)— The QEPI index input can be used to trigger the initialization of the position counter at the rising or falling edge of the index input. If the QEPCTL[IEI] bits are 10, then the position counter (QPOSCNT) is initialized with a value in the QPOSINIT register on the rising edge of index input. Conversely, if the QEPCTL[IEI] bits are 11, initialization will be on the falling edge of the index input.
- **Strobe Event Initialization (SEI)** If the QEPCTL[SEI] bits are 10, then the position counter is initialized with a value in the QPOSINIT register on the rising edge of strobe input.

If QEPCTL[SEL] bits are 11, then the position counter is initialized with a value in the QPOSINIT register on the rising edge of strobe input for forward direction and on the falling edge of strobe input for reverse direction.

**Software Initialization (SWI)**— The position counter can be initialized in software by writing a 1 to the QEPCTL[SWI] bit. This bit is not automatically cleared. While the bit is still set, if a 1 is written to it again, the position counter will be re-initialized.

## 5.4.4 eQEP Position-compare Unit

The eQEP peripheral includes a position-compare unit that is used to generate a sync output and/or interrupt on a position-compare match. Figure 5-12 shows a diagram. The position-compare (QPOSCMP) register is shadowed and shadow mode can be enabled or disabled using the QPOSCTL[PSSHDW] bit. If the shadow mode is not enabled, the CPU writes directly to the active position compare register.



## Figure 5-12. eQEP Position-compare Unit

In shadow mode, you can configure the position-compare unit (QPOSCTL[PCLOAD]) to load the shadow register value into the active register on the following events and to generate the position-compare ready (QFLG[PCR]) interrupt after loading.

- Load on compare match
- Load on position-counter zero event

The position-compare match (QFLG[PCM]) is set when the position-counter value (QPOSCNT) matches with the active position-compare register (QPOSCMP) and the position-compare sync output of the programmable pulse width is generated on compare match to trigger an external device.



#### Position Counter and Control Unit (PCCU)

www.ti.com

For example, if QPOSCMP = 2, the position-compare unit generates a position-compare event on 1 to 2 transitions of the eQEP position counter for forward counting direction and on 3 to 2 transitions of the eQEP position counter for reverse counting direction (see Figure 5-13).

Figure 5-23 shows the layout of the eQEP Position-Compare Control Register (QPOSCTL) and Table 5-5 describes the QPOSCTL bit fields.



#### Figure 5-13. eQEP Position-compare Event Generation Points

The pulse stretcher logic in the position-compare unit generates a programmable position-compare sync pulse output on the position-compare match. In the event of a new position-compare match while a previous position-compare pulse is still active, then the pulse stretcher generates a pulse of specified duration from the new position-compare event as shown in Figure 5-14.







(3)

## 5.5 eQEP Edge Capture Unit

The eQEP peripheral includes an integrated edge capture unit to measure the elapsed time between the unit position events as shown in Figure 5-15. This feature is typically used for low speed measurement using the following equation:

$$v(k) = \frac{X}{t(k) - t(k-1)} = \frac{X}{\Delta T}$$

where,

- X Unit position is defined by integer multiple of quadrature edges (see Figure 5-16)
- ΔT Elapsed time between unit position events
- v(k) Velocity at time instant "k"

The eQEP capture timer (QCTMR) runs from prescaled SYSCLKOUT and the prescaler is programmed by the QCAPCTL[CCPS] bits. The capture timer (QCTMR) value is latched into the capture period register (QCPRD) on every unit position event and then the capture timer is reset, a flag is set in QEPSTS:UPEVNT to indicate that new value is latched into the QCPRD register. Software can check this status flag before reading the period register for low speed measurement and clear the flag by writing 1.

Time measurement ( $\Delta T$ ) between unit position events will be correct if the following conditions are met:

- No more than 65,535 counts have occurred between unit position events.
- No direction change between unit position events.

The capture unit sets the eQEP overflow error flag (QEPSTS[COEF]) in the event of capture timer overflow between unit position events. If a direction change occurs between the unit position events, then an error flag is set in the status register (QEPSTS[CDEF]).

Capture Timer (QCTMR) and Capture period register (QCPRD) can be configured to latch on following events.

- CPU read of QPOSCNT register
- Unit time-out event

If the QEPCTL[QCLM] bit is cleared, then the capture timer and capture period values are latched into the QCTMRLAT and QCPRDLAT registers, respectively, when the CPU reads the position counter (QPOSCNT).

If the QEPCTL[QCLM] bit is set, then the position counter, capture timer, and capture period values are latched into the QPOSLAT, QCTMRLAT and QCPRDLAT registers, respectively, on unit time out.

Figure 5-17 shows the capture unit operation along with the position counter.





**NOTE:** The QCAPCTL[UPPS] prescaler should not be modified dynamically (such as switching the unit event prescaler from QCLK/4 to QCLK/8). Doing so may result in undefined behavior. The QCAPCTL[CPPS] prescaler can be modified dynamically (such as switching CAPCLK prescaling mode from SYSCLK/4 to SYSCLK/8) only after the capture unit is disabled.





A N - Number of quadrature periods selected using QCAPCTL[UPPS] bits



(4)



#### where

- v(k): Velocity at time instant k
- x(k): Position at time instant k
- x(k-1): Position at time instant k-1
- T: Fixed unit time or inverse of velocity calculation rate
- $\Delta X$ : Incremental position movement in unit time
- X: Fixed unit position
- $\Delta T$ : Incremental time elapsed for unit position movement
- t(k): Time instant "k"
- t(k-1): Time instant "k-1"

Unit time (T) and unit period(X) are configured using the QUPRD and QCAPCTL[UPPS] registers. Incremental position output and incremental time output is available in the QPOSLAT and QCPRDLAT registers.



#### eQEP Watchdog

| Parameter | Relevant Register to Configure or Read the Information                  |
|-----------|-------------------------------------------------------------------------|
| Т         | Unit Period Register (QUPRD)                                            |
| ΔΧ        | Incremental Position = QPOSLAT(k) - QPOSLAT(K-1)                        |
| X         | Fixed unit position defined by sensor resolution and ZCAPCTL[UPPS] bits |
| ΔΤ        | Capture Period Latch (QCPRDLAT)                                         |

## 5.6 eQEP Watchdog

The eQEP peripheral contains a 16-bit watchdog timer that monitors the quadrature-clock to indicate proper operation of the motion-control system. The eQEP watchdog timer is clocked from SYSCLKOUT/64 and the quadrate clock event (pulse) resets the watchdog timer. If no quadrature-clock event is detected until a period match (QWDPRD = QWDTMR), then the watchdog timer will time out and the watchdog interrupt flag will be set (QFLG[WTO]). The time-out value is programmable through the watchdog period register (QWDPRD).



Figure 5-18. eQEP Watchdog Timer

#### 5.7 Unit Timer Base

The eQEP peripheral includes a 32-bit timer (QUTMR) that is clocked by SYSCLKOUT to generate periodic interrupts for velocity calculations. The unit time out interrupt is set (QFLG[UTO]) when the unit timer (QUTMR) matches the unit period register (QUPRD).

The eQEP peripheral can be configured to latch the position counter, capture timer, and capture period values on a unit time out event so that latched values are used for velocity calculation as described in Section Section 5.5.



Figure 5-19. eQEP Unit Time Base



## 5.8 eQEP Interrupt Structure

Figure 5-20 shows how the interrupt mechanism works in the EQEP module.



Eleven interrupt events (PCE, PHE, QDC, WTO, PCU, PCO, PCR, PCM, SEL, IEL and UTO) can be generated. The interrupt control register (QEINT) is used to enable/disable individual interrupt event sources. The interrupt flag register (QFLG) indicates if any interrupt event has been latched and contains the global interrupt flag bit (INT). An interrupt pulse is generated only to the PIE if any of the interrupt events is enabled, the flag bit is 1 and the INT flag bit is 0. The interrupt service routine will need to clear the global interrupt flag bit and the serviced event, via the interrupt clear register (QCLR), before any other interrupt pulses are generated. You can force an interrupt event by way of the interrupt force register (QFRC), which is useful for test purposes.

## 5.9 eQEP Registers

|       |       | gui e e I |                   |     |          |       |     |  |  |
|-------|-------|-----------|-------------------|-----|----------|-------|-----|--|--|
| 15    | 14    | 13        | 12                | 11  | 10       | 9     | 8   |  |  |
| Q     | SRC   | SOEN      | SPSEL             | XCR | SWAP     | IGATE | QAP |  |  |
| R/    | R/W-0 |           | R/W-0 R/W-0 R/W-0 |     | R/W-0    | R/W-0 |     |  |  |
| 7     | 6     | 5         | 4                 |     |          |       | 0   |  |  |
| QBP   | QIP   | QSP       |                   |     | Reserved |       |     |  |  |
| R/W-0 | R/W-0 | R/W-0     | R-0               |     |          |       |     |  |  |

#### Figure 5-21. QEP Decoder Control (QDECCTL) Register

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bits  | Name | Value | Description                                                          |
|-------|------|-------|----------------------------------------------------------------------|
| 15-14 | QSRC |       | Position-counter source selection                                    |
|       |      | 00    | Quadrature count mode (QCLK = iCLK, QDIR = iDIR)                     |
|       |      | 01    | Direction-count mode (QCLK = xCLK, QDIR = xDIR)                      |
|       |      | 10    | UP count mode for frequency measurement (QCLK = xCLK, QDIR = 1)      |
|       |      | 11    | DOWN count mode for frequency measurement<br>(QCLK = xCLK, QDIR = 0) |
| 13    | SOEN |       | Sync output-enable                                                   |
|       |      | 0     | Disable position-compare sync output                                 |
|       |      | 1     | Enable position-compare sync output                                  |

| Bits | Name     | Value | Description                                                                                                     |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------|
| 12   | SPSEL    |       | Sync output pin selection                                                                                       |
|      |          | 0     | Index pin is used for sync output                                                                               |
|      |          | 1     | Strobe pin is used for sync output                                                                              |
| 11   | XCR      |       | External clock rate                                                                                             |
|      |          | 0     | 2x resolution: Count the rising/falling edge                                                                    |
|      |          | 1     | 1x resolution: Count the rising edge only                                                                       |
| 10   | SWAP     |       | Swap quadrature clock inputs. This swaps the input to the quadrature decoder, reversing the counting direction. |
|      |          | 0     | Quadrature-clock inputs are not swapped                                                                         |
|      |          | 1     | Quadrature-clock inputs are swapped                                                                             |
| 9    | IGATE    |       | Index pulse gating option                                                                                       |
|      |          | 0     | Disable gating of Index pulse                                                                                   |
|      |          | 1     | Gate the index pin with strobe                                                                                  |
| 8    | QAP      |       | QEPA input polarity                                                                                             |
|      |          | 0     | No effect                                                                                                       |
|      |          | 1     | Negates QEPA input                                                                                              |
| 7    | QBP      |       | QEPB input polarity                                                                                             |
|      |          | 0     | No effect                                                                                                       |
|      |          | 1     | Negates QEPB input                                                                                              |
| 6    | QIP      |       | QEPI input polarity                                                                                             |
|      |          | 0     | No effect                                                                                                       |
|      |          | 1     | Negates QEPI input                                                                                              |
| 5    | QSP      |       | QEPS input polarity                                                                                             |
|      |          | 0     | No effect                                                                                                       |
|      |          | 1     | Negates QEPS input                                                                                              |
| 4-0  | Reserved |       | Always write as 0                                                                                               |

# Table 5-3. eQEP Decoder Control (QDECCTL) Register Field Descriptions (continued)

## Figure 5-22. eQEP Control (QEPCTL) Register

| 15                                                              | 14             | 13          | 12 | 11      | 10  | 9   | 8     | 7     | 6   | 5    | 4     | 3     | 2     | 1     | 0 |
|-----------------------------------------------------------------|----------------|-------------|----|---------|-----|-----|-------|-------|-----|------|-------|-------|-------|-------|---|
| FREE,                                                           | REE, SOFT PCRM |             | RM | SEI IEI |     | SWI | SEL   | IE    | L   | QPEN | QCLM  | UTE   | WDE   |       |   |
| R/W                                                             | V-0            | R/W-0 R/W-0 |    | V-0     | R/\ | V-0 | R/W-0 | R/W-0 | R/V | /-0  | R/W-0 | R/W-0 | R/W-0 | R/W-0 |   |
| LEGEND: R/W = Read/Write: R = Read only: -n = value after reset |                |             |    |         |     |     |       |       |     |      |       |       |       |       |   |

GEND: R/W = Read/Write; R = Read only; -*n* = value after reset



| Bits  | Name  | Value    | Description                                                                                                                                                                                               |
|-------|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14 | FREE, |          | Emulation Control Bits                                                                                                                                                                                    |
|       | SOFT  |          | QPOSCNT behavior                                                                                                                                                                                          |
|       |       | 00       | Position counter stops immediately on emulation suspend                                                                                                                                                   |
|       |       | 01       | Position counter continues to count until the rollover                                                                                                                                                    |
|       |       | 1x       | Position counter is unaffected by emulation suspend                                                                                                                                                       |
|       |       |          | QWDTMR behavior                                                                                                                                                                                           |
|       |       | 00<br>01 | Watchdog counter stops immediately<br>Watchdog counter counts until WD period match roll over                                                                                                             |
|       |       | 1x       | Watchdog counter is unaffected by emulation suspend                                                                                                                                                       |
|       |       |          | QUTMR behavior                                                                                                                                                                                            |
|       |       | 00       | Unit timer stops immediately                                                                                                                                                                              |
|       |       | 01       | Unit timer counts until period rollover                                                                                                                                                                   |
|       |       | 1x       | Unit timer is unaffected by emulation suspend                                                                                                                                                             |
|       |       |          | QCTMR behavior                                                                                                                                                                                            |
|       |       | 00<br>01 | Capture Timer stops immediately<br>Capture Timer counts until next unit period event                                                                                                                      |
|       |       | 1x       | Capture Timer is unaffected by emulation suspend                                                                                                                                                          |
| 13-12 | PCRM  |          | Position counter reset mode                                                                                                                                                                               |
|       |       | 00       | Position counter reset on an index event                                                                                                                                                                  |
|       |       | 01       | Position counter reset on the maximum position                                                                                                                                                            |
|       |       | 10       | Position counter reset on the first index event                                                                                                                                                           |
|       |       | 11       | Position counter reset on a unit time event                                                                                                                                                               |
| 11-10 | SEI   |          | Strobe event initialization of position counter                                                                                                                                                           |
|       |       | 00       | Does nothing (action disabled)                                                                                                                                                                            |
|       |       | 01       | Does nothing (action disabled)                                                                                                                                                                            |
|       |       | 10       | Initializes the position counter on rising edge of the QEPS signal                                                                                                                                        |
|       |       | 11       | Clockwise Direction:                                                                                                                                                                                      |
|       |       |          | Initializes the position counter on the rising edge of QEPS strobe<br>Counter Clockwise Direction:                                                                                                        |
|       |       |          | Initializes the position counter on the falling edge of QEPS strobe                                                                                                                                       |
| 9-8   | IEI   |          | Index event initialization of position counter                                                                                                                                                            |
|       |       | 00       | Do nothing (action disabled)                                                                                                                                                                              |
|       |       | 01       | Do nothing (action disabled)                                                                                                                                                                              |
|       |       | 10       | Initializes the position counter on the rising edge of the QEPI signal (QPOSCNT = QPOSINIT)                                                                                                               |
|       |       | 11       | Initializes the position counter on the falling edge of QEPI signal (QPOSCNT = QPOSINIT)                                                                                                                  |
| 7     | SWI   |          | Software initialization of position counter                                                                                                                                                               |
|       |       | 0        | Do nothing (action disabled)                                                                                                                                                                              |
|       |       | 1        | Initialize position counter (QPOSCNT=QPOSINIT). This bit is not cleared automatically                                                                                                                     |
| 6     | SEL   |          | Strobe event latch of position counter                                                                                                                                                                    |
|       |       | 0        | The position counter is latched on the rising edge of QEPS strobe (QPOSSLAT = POSCCNT). Latching on the falling edge can be done by inverting the strobe input using the QSP bit in the QDECCTL register. |
|       |       | 1        | Clockwise Direction:                                                                                                                                                                                      |
|       |       |          | Position counter is latched on rising edge of QEPS strobe                                                                                                                                                 |
|       |       |          | Counter Clockwise Direction:<br>Position counter is latched on falling edge of QEPS strobe                                                                                                                |
| 5-4   | IEL   |          | Index event latch of position counter (software index marker)                                                                                                                                             |
|       |       | 00       | Reserved                                                                                                                                                                                                  |
|       |       | 01       | Latches position counter on rising edge of the index signal                                                                                                                                               |
|       |       | 10       | Latches position counter on falling edge of the index signal                                                                                                                                              |
|       |       | 11       | Software index marker. Latches the position counter and quadrature direction flag on index                                                                                                                |
|       |       |          | event marker. The position counter is latched to the QPOSILAT register and the direction flag is latched in the QEPSTS[QDLF] bit. This mode is useful for software index marking.                         |

Table 5-4. eQEP Control (QEPCTL) Register Field Descriptions



| Bits | Name | Value | Description                                                                                                                                                          |  |
|------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 3    | QPEN |       | Quadrature position counter enable/software reset                                                                                                                    |  |
|      |      | 0     | Reset the eQEP peripheral internal operating flags/read-only registers. Control/configuration registers are not disturbed by a software reset.                       |  |
|      |      | 1     | eQEP position counter is enabled                                                                                                                                     |  |
| 2    | QCLM |       | eQEP capture latch mode                                                                                                                                              |  |
|      |      | 0     | Latch on position counter read by CPU. Capture timer and capture period values are latched into QCTMRLAT and QCPRDLAT registers when CPU reads the QPOSCNT register. |  |
|      |      | 1     | Latch on unit time out. Position counter, capture timer and capture period values are latched into QPOSLAT, QCTMRLAT and QCPRDLAT registers on unit time out.        |  |
| 1    | UTE  |       | eQEP unit timer enable                                                                                                                                               |  |
|      |      | 0     | Disable eQEP unit timer                                                                                                                                              |  |
|      |      | 1     | Enable unit timer                                                                                                                                                    |  |
| 0    | WDE  |       | QEP watchdog enable                                                                                                                                                  |  |
|      |      | 0     | Disable the eQEP watchdog timer                                                                                                                                      |  |
|      |      | 1     | Enable the eQEP watchdog timer                                                                                                                                       |  |

## Table 5-4. eQEP Control (QEPCTL) Register Field Descriptions (continued)

## Figure 5-23. eQEP Position-compare Control (QPOSCTL) Register

| 15     | 14     | 13    | 12    | 11  |       | 8 |
|--------|--------|-------|-------|-----|-------|---|
| PCSHDW | PCLOAD | PCPOL | PCE   |     | PCSPW |   |
| R/W-0  | R/W-0  | R/W-0 | R/W-0 |     | R/W-0 |   |
| 7      |        |       |       |     |       | 0 |
|        |        |       | PCS   | PW  |       |   |
|        |        |       | R/V   | V-0 |       |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 5-5. eQEP Position-compare Control (QPOSCTL) Register Field Descriptions

| Bit  | Name   |       | Description                                     |
|------|--------|-------|-------------------------------------------------|
| 15   | PCSHDW |       | Position-compare shadow enable                  |
|      |        | 0     | Shadow disabled, load Immediate                 |
|      |        | 1     | Shadow enabled                                  |
| 14   | PCLOAD |       | Position-compare shadow load mode               |
|      |        | 0     | Load on QPOSCNT = 0                             |
|      |        | 1     | Load when QPOSCNT = QPOSCMP                     |
| 13   | PCPOL  |       | Polarity of sync output                         |
|      |        | 0     | Active HIGH pulse output                        |
|      |        | 1     | Active LOW pulse output                         |
| 12   | PCE    |       | Position-compare enable/disable                 |
|      |        | 0     | Disable position compare unit                   |
|      |        | 1     | Enable position compare unit                    |
| 11-0 | PCSPW  |       | Select-position-compare sync output pulse width |
|      |        | 0x000 | 1 * 4 * SYSCLKOUT cycles                        |
|      |        | 0x001 | 2 * 4 * SYSCLKOUT cycles                        |
|      |        | 0xFFF | 4096 * 4 * SYSCLKOUT cycles                     |



eQEP Registers

| Figure 5-24. eQEP Capture Control (QCAPCTL) Register            |    |          |   |      |   |   |       |   |
|-----------------------------------------------------------------|----|----------|---|------|---|---|-------|---|
| 15                                                              | 14 |          | 7 | 6    | 4 | 3 |       | 0 |
| CEN                                                             |    | Reserved |   | CCP  | S |   | UPPS  |   |
| R/W-0                                                           |    | R-0      |   | R/W- | 0 |   | R/W-0 |   |
| LEGEND: R/M - Read/Write: R - Read only: -n - value after reset |    |          |   |      |   |   |       |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 5-6. eQEP Capture Control (QCAPCTL) Register Field Descriptions

| Bits | Name     | Descrip                                                                                      | tion                                                                                                                                                                                                                                                                                                              |
|------|----------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | CEN      |                                                                                              | Enable eQEP capture                                                                                                                                                                                                                                                                                               |
|      |          | 0                                                                                            | eQEP capture unit is disabled                                                                                                                                                                                                                                                                                     |
|      |          | 1                                                                                            | eQEP capture unit is enabled                                                                                                                                                                                                                                                                                      |
| 14-7 | Reserved |                                                                                              | Always write as 0                                                                                                                                                                                                                                                                                                 |
| 6-4  | CCPS     |                                                                                              | eQEP capture timer clock prescaler                                                                                                                                                                                                                                                                                |
|      |          | 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111                                         | CAPCLK = SYSCLKOUT/1<br>CAPCLK = SYSCLKOUT/2<br>CAPCLK = SYSCLKOUT/4<br>CAPCLK = SYSCLKOUT/8<br>CAPCLK = SYSCLKOUT/16<br>CAPCLK = SYSCLKOUT/32<br>CAPCLK = SYSCLKOUT/64<br>CAPCLK = SYSCLKOUT/128                                                                                                                 |
| 3-0  | UPPS     | 0000<br>0011<br>0010<br>0011<br>0100<br>0101<br>0110<br>1000<br>1001<br>1010<br>1011<br>11xx | Unit position event prescaler<br>UPEVNT = QCLK/1<br>UPEVNT = QCLK/2<br>UPEVNT = QCLK/4<br>UPEVNT = QCLK/8<br>UPEVNT = QCLK/16<br>UPEVNT = QCLK/32<br>UPEVNT = QCLK/32<br>UPEVNT = QCLK/128<br>UPEVNT = QCLK/256<br>UPEVNT = QCLK/512<br>UPEVNT = QCLK/512<br>UPEVNT = QCLK/1024<br>UPEVNT = QCLK/2048<br>Reserved |

## Figure 5-25. eQEP Position Counter (QPOSCNT) Register

| 31      | 0 |
|---------|---|
| QPOSCNT |   |
| R/W-0   |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 5-7. eQEP Position Counter (QPOSCNT) Register Field Descriptions

| Bits | Name    | Description                                                                                                                                                                                                              |
|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | QPOSCNT | This 32-bit position counter register counts up/down on every eQEP pulse based on direction input. This counter acts as a position integrator whose count value is proportional to position from a give reference point. |

## Figure 5-26. eQEP Position Counter Initialization (QPOSINIT) Register

31

QPOSINIT

R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

0



eQEP Registers

~ 4

#### www.ti.com

| Bits | Name     | Description                                                                                                                                                                                                                                               |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | QPOSINIT | This register contains the position value that is used to initialize the position counter based on external strobe or index event. The position counter can be initialized through software. Writes to this register should always be full 32-bit writes. |

## Figure 5-27. eQEP Maximum Position Count Register (QPOSMAX) Register

| 31 0    | 1 |
|---------|---|
| QPOSMAX |   |
| R/W-0   |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 5-9. eQEP Maximum Position Count (QPOSMAX) Register Field Descriptions

| Bits | Name    | Description                                                                                                             |
|------|---------|-------------------------------------------------------------------------------------------------------------------------|
| 31-0 | QPOSMAX | This register contains the maximum position counter value. Writes to this register should always be full 32-bit writes. |

#### Figure 5-28. eQEP Position-compare (QPOSCMP) Register

| 31 |         | J |
|----|---------|---|
|    | QPOSCMP |   |
|    | R/W-0   |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 5-10. eQEP Position-compare (QPOSCMP) Register Field Descriptions

| E | Bits | Name    | Description                                                                                                                                            |
|---|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | 1-0  | QPOSCMP | The position-compare value in this register is compared with the position counter (QPOSCNT) to generate sync output and/or interrupt on compare match. |

## Figure 5-29. eQEP Index Position Latch (QPOSILAT) Register

| 31 |          | 0 |
|----|----------|---|
|    | QPOSILAT |   |
|    | R-0      |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 5-11. eQEP Index Position Latch(QPOSILAT) Register Field Descriptions

| Bits | Name     | Description                                                                                                    |
|------|----------|----------------------------------------------------------------------------------------------------------------|
| 31-0 | QPOSILAT | The position-counter value is latched into this register on an index event as defined by the QEPCTL[IEL] bits. |

#### Figure 5-30. eQEP Strobe Position Latch (QPOSSLAT) Register

| 31       | 0 |
|----------|---|
| QPOSSLAT |   |
| R-O      |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

31

### Table 5-12. eQEP Strobe Position Latch (QPOSSLAT) Register Field Descriptions

| Bits | Name     | Description                                                                                                  |
|------|----------|--------------------------------------------------------------------------------------------------------------|
| 31-0 | QPOSSLAT | The position-counter value is latched into this register on strobe event as defined by the QEPCTL[SEL] bits. |

### Figure 5-31. eQEP Position Counter Latch (QPOSLAT) Register

| 31      | 0 |
|---------|---|
| QPOSLAT |   |
| R-0     |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 5-13. eQEP Position Counter Latch (QPOSLAT) Register Field Descriptions

| Bits | Name    | Description                                                                      |  |
|------|---------|----------------------------------------------------------------------------------|--|
| 31-0 | QPOSLAT | The position-counter value is latched into this register on unit time out event. |  |

# Figure 5-32. eQEP Unit Timer (QUTMR) Register

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

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 5-14. eQEP Unit Timer (QUTMR) Register Field Descriptions

| Bit | Name    | Description                                                                                                                                              |  |
|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31- | ) QUTMR | This register acts as time base for unit time event generation. When this timer value matches with unit time period value, unit time event is generated. |  |

# Figure 5-33. eQEP Register Unit Period (QUPRD) Register

| 31    | 0 |
|-------|---|
| QUPRD |   |
| R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 5-15. eQEP Unit Period (QUPRD) Register Field Descriptions

| Bits Name Description |  | Description                                                                                                                                                                                                                                                 |
|-----------------------|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0                  |  | This register contains the period count for unit timer to generate periodic unit time events to latch the eQEP position information at periodic interval and optionally to generate interrupt. Writes to this register should always be full 32-bit writes. |

# Figure 5-34. eQEP Watchdog Timer (QWDTMR) Register

| 15     | 0 |
|--------|---|
| QWDTMR |   |
| R/W-0  |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

| Table 5-16. eQEP Watchdog Timer (QWDTMR) Register Field Descriptions |  |
|----------------------------------------------------------------------|--|
|----------------------------------------------------------------------|--|

| Bits | Name   | Description                                                                                                                                                                                                                                                       |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | QWDTMR | This register acts as time base for watch dog to detect motor stalls. When this timer value matches with watch dog period value, watch dog timeout interrupt is generated. This register is reset upon edge transition in quadrature-clock indicating the motion. |

# Figure 5-35. eQEP Watchdog Period (QWDPRD) Register

| 15 |        | 0 |
|----|--------|---|
|    | QWDPRD |   |
|    | R/W-0  |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 5-17. eQEP Watchdog Period (QWDPRD) Register Field Description

| Bits | Name   | Value | Description                                                                                                                                                                                       |
|------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | QWDPRD |       | This register contains the time-out count for the eQEP peripheral watch dog timer.<br>When the watchdog timer value matches the watchdog period value, a watchdog timeout interrupt is generated. |

### Figure 5-36. eQEP Interrupt Enable (QEINT) Register

| 15    |       |       | 12    | 11    | 10    | 9     | 8        |
|-------|-------|-------|-------|-------|-------|-------|----------|
|       | Rese  | erved |       | UTO   | IEL   | SEL   | PCM      |
|       | R     | -0    |       | R/W-0 | R/W-0 | R/W-0 | R/W-0    |
| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0        |
| PCR   | PCO   | PCU   | WTO   | QDC   | QPE   | PCE   | Reserved |
| R/W-0 | R-0      |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 5-18. eQEP Interrupt Enable(QEINT) Register Field Descriptions

| Bits  | Name     | Value | Description                                |
|-------|----------|-------|--------------------------------------------|
| 15-12 | Reserved | 0     | Always write as 0                          |
| 11    | UTO      |       | Unit time out interrupt enable             |
|       |          | 0     | Interrupt is disabled                      |
|       |          | 1     | Interrupt is enabled                       |
| 10    | IEL      |       | Index event latch interrupt enable         |
|       |          | 0     | Interrupt is disabled                      |
|       |          | 1     | Interrupt is enabled                       |
| 9     | SEL      |       | Strobe event latch interrupt enable        |
|       |          | 0     | Interrupt is disabled                      |
|       |          | 1     | Interrupt is enabled                       |
| 8     | PCM      |       | Position-compare match interrupt enable    |
|       |          | 0     | Interrupt is disabled                      |
|       |          | 1     | Interrupt is enabled                       |
| 7     | PCR      |       | Position-compare ready interrupt enable    |
|       |          | 0     | Interrupt is disabled                      |
|       |          | 1     | Interrupt is enabled                       |
| 6     | PCO      |       | Position counter overflow interrupt enable |
|       |          | 0     | Interrupt is disabled                      |



| Bits | Name     | Value | Description                                  |
|------|----------|-------|----------------------------------------------|
|      |          | 1     | Interrupt is enabled                         |
| 5    | PCU      |       | Position counter underflow interrupt enable  |
|      |          | 0     | Interrupt is disabled                        |
|      |          | 1     | Interrupt is enabled                         |
| 4    | WTO      |       | Watchdog time out interrupt enable           |
|      |          | 0     | Interrupt is disabled                        |
|      |          | 1     | Interrupt is enabled                         |
| 3    | QDC      |       | Quadrature direction change interrupt enable |
|      |          | 0     | Interrupt is disabled                        |
|      |          | 1     | Interrupt is enabled                         |
| 2    | QPE      |       | Quadrature phase error interrupt enable      |
|      |          | 0     | Interrupt is disabled                        |
|      |          | 1     | Interrupt is enabled                         |
| 1    | PCE      |       | Position counter error interrupt enable      |
|      |          | 0     | Interrupt is disabled                        |
|      |          | 1     | Interrupt is enabled                         |
| 0    | Reserved |       | Reserved                                     |

# Table 5-18. eQEP Interrupt Enable(QEINT) Register Field Descriptions (continued)

# Figure 5-37. eQEP Interrupt Flag (QFLG) Register

| 15  |      |       | 12  | 11  | 10  | 9   | 8   |
|-----|------|-------|-----|-----|-----|-----|-----|
|     | Rese | erved |     | UTO | IEL | SEL | PCM |
|     | R    | -0    |     | R-0 | R-0 | R-0 | R-0 |
| 7   | 6    | 5     | 4   | 3   | 2   | 1   | 0   |
| PCR | PCO  | PCU   | WTO | QDC | PHE | PCE | INT |
| R-0 | R-0  | R-0   | R-0 | R-0 | R-0 | R-0 | R-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 5-19. eQEP Interrupt Flag (QFLG) Register Field Descriptions

| Bits      | Name     | Value | Description                                                                                           |
|-----------|----------|-------|-------------------------------------------------------------------------------------------------------|
| 15-<br>12 | Reserved |       | Always write as 0                                                                                     |
| 11        | UTO      |       | Unit time out interrupt flag                                                                          |
|           |          | 0     | No interrupt generated                                                                                |
|           |          | 1     | Set by eQEP unit timer period match                                                                   |
| 10        | IEL      |       | Index event latch interrupt flag                                                                      |
|           |          | 0     | No interrupt generated                                                                                |
|           |          | 1     | This bit is set after latching the QPOSCNT to QPOSILAT                                                |
| 9         | SEL      |       | Strobe event latch interrupt flag                                                                     |
|           |          | 0     | No interrupt generated                                                                                |
|           |          | 1     | This bit is set after latching the QPOSCNT to QPOSSLAT                                                |
| 8         | PCM      |       | eQEP compare match event interrupt flag                                                               |
|           |          | 0     | No interrupt generated                                                                                |
|           |          | 1     | This bit is set on position-compare match                                                             |
| 7         | PCR      |       | Position-compare ready interrupt flag                                                                 |
|           |          | 0     | No interrupt generated                                                                                |
|           |          | 1     | This bit is set after transferring the shadow register value to the active position compare register. |
| 6         | PCO      |       | Position counter overflow interrupt flag                                                              |

| Bits | Name | Value | Description                                     |
|------|------|-------|-------------------------------------------------|
|      |      | 0     | No interrupt generated                          |
|      |      | 1     | This bit is set on position counter overflow.   |
| 5    | PCU  |       | Position counter underflow interrupt flag       |
|      |      | 0     | No interrupt generated                          |
|      |      | 1     | This bit is set on position counter underflow.  |
| 4    | WTO  |       | Watchdog timeout interrupt flag                 |
|      |      | 0     | No interrupt generated                          |
|      |      | 1     | Set by watch dog timeout                        |
| 3    | QDC  |       | Quadrature direction change interrupt flag      |
|      |      | 0     | No interrupt generated                          |
|      |      | 1     | This bit is set during change of direction      |
| 2    | PHE  |       | Quadrature phase error interrupt flag           |
|      |      | 0     | No interrupt generated                          |
|      |      | 1     | Set on simultaneous transition of QEPA and QEPB |
| 1    | PCE  |       | Position counter error interrupt flag           |
|      |      | 0     | No interrupt generated                          |
|      |      | 1     | Position counter error                          |
| 0    | INT  |       | Global interrupt status flag                    |
|      |      | 0     | No interrupt generated                          |
|      |      | 1     | Interrupt was generated                         |

# Table 5-19. eQEP Interrupt Flag (QFLG) Register Field Descriptions (continued)

# Figure 5-38. eQEP Interrupt Clear (QCLR) Register

| 15    |       |       | 12    | 11    | 10    | 9     | 8     |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       | Rese  | erved |       | UTO   | IEL   | SEL   | PCM   |
| R-0   |       |       |       | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| PCR   | PCO   | PCU   | WTO   | QDC   | PHE   | PCE   | INT   |
| R/W-0 |
|       |       |       |       |       |       |       |       |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 5-20. eQEP Interrupt Clear (QCLR) Register Field Descriptions

| Bit   | Field    | Value | Description                                   |
|-------|----------|-------|-----------------------------------------------|
| 15-12 | Reserved |       | Always write as 0s                            |
| 11    | UTO      |       | Clear unit time out interrupt flag            |
|       |          | 0     | No effect                                     |
|       |          | 1     | Clears the interrupt flag                     |
| 10    | IEL      |       | Clear index event latch interrupt flag        |
|       |          | 0     | No effect                                     |
|       |          | 1     | Clears the interrupt flag                     |
| 9     | SEL      |       | Clear strobe event latch interrupt flag       |
|       |          | 0     | No effect                                     |
|       |          | 1     | Clears the interrupt flag                     |
| 8     | PCM      |       | Clear eQEP compare match event interrupt flag |
|       |          | 0     | No effect                                     |
|       |          | 1     | Clears the interrupt flag                     |



| Bit        | Field | Value | Description                                                                                             |
|------------|-------|-------|---------------------------------------------------------------------------------------------------------|
| - Біі<br>7 | PCR   | value |                                                                                                         |
|            | PCR   |       | Clear position-compare ready interrupt flag                                                             |
|            |       | 0     | No effect                                                                                               |
|            |       | 1     | Clears the interrupt flag                                                                               |
| 6          | PCO   |       | Clear position counter overflow interrupt flag                                                          |
|            |       | 0     | No effect                                                                                               |
|            |       | 1     | Clears the interrupt flag                                                                               |
| 5          | PCU   |       | Clear position counter underflow interrupt flag                                                         |
|            |       | 0     | No effect                                                                                               |
|            |       | 1     | Clears the interrupt flag                                                                               |
| 4          | WTO   |       | Clear watchdog timeout interrupt flag                                                                   |
|            |       | 0     | No effect                                                                                               |
|            |       | 1     | Clears the interrupt flag                                                                               |
| 3          | QDC   |       | Clear quadrature direction change interrupt flag                                                        |
|            |       | 0     | No effect                                                                                               |
|            |       | 1     | Clears the interrupt flag                                                                               |
| 2          | PHE   |       | Clear quadrature phase error interrupt flag                                                             |
|            |       | 0     | No effect                                                                                               |
|            |       | 1     | Clears the interrupt flag                                                                               |
| 1          | PCE   |       | Clear position counter error interrupt flag                                                             |
|            |       | 0     | No effect                                                                                               |
|            |       | 1     | Clears the interrupt flag                                                                               |
| 0          | INT   |       | Global interrupt clear flag                                                                             |
|            |       | 0     | No effect                                                                                               |
|            |       | 1     | Clears the interrupt flag and enables further interrupts to be generated if an event flags is set to 1. |

# Table 5-20. eQEP Interrupt Clear (QCLR) Register Field Descriptions (continued)

# Figure 5-39. eQEP Interrupt Force (QFRC) Register

| 15    |       |       | 12    | 11    | 10    | 9     | 8        |
|-------|-------|-------|-------|-------|-------|-------|----------|
|       | Rese  | erved |       | UTO   | IEL   | SEL   | PCM      |
| R-0   |       |       |       | R/W-0 | R/W-0 | R/W-0 | R/W-0    |
| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0        |
| PCR   | PCO   | PCU   | WTO   | QDC   | PHE   | PCE   | Reserved |
| R/W-0 | R-0      |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 5-21. eQEP Interrupt Force (QFRC) Register Field Descriptions

| Bit   | Field    | Value | Description                        |
|-------|----------|-------|------------------------------------|
| 15-12 | Reserved |       | Always write as 0s                 |
| 11    | UTO      |       | Force unit time out interrupt      |
|       |          | 0     | No effect                          |
|       |          | 1     | Force the interrupt                |
| 10    | IEL      |       | Force index event latch interrupt  |
|       |          | 0     | No effect                          |
|       |          | 1     | Force the interrupt                |
| 9     | SEL      |       | Force strobe event latch interrupt |
|       |          | 0     | No effect                          |
|       |          | 1     | Force the interrupt                |



| Bit | Field    | Value | Description                                 |
|-----|----------|-------|---------------------------------------------|
| 8   | PCM      |       | Force position-compare match interrupt      |
|     |          | 0     | No effect                                   |
|     |          | 1     | Force the interrupt                         |
| 7   | PCR      |       | Force position-compare ready interrupt      |
|     |          | 0     | No effect                                   |
|     |          | 1     | Force the interrupt                         |
| 6   | PCO      |       | Force position counter overflow interrupt   |
|     |          | 0     | No effect                                   |
|     |          | 1     | Force the interrupt                         |
| 5   | PCU      |       | Force position counter underflow interrupt  |
|     |          | 0     | No effect                                   |
|     |          | 1     | Force the interrupt                         |
| 4   | WTO      |       | Force watchdog time out interrupt           |
|     |          | 0     | No effect                                   |
|     |          | 1     | Force the interrupt                         |
| 3   | QDC      |       | Force quadrature direction change interrupt |
|     |          | 0     | No effect                                   |
|     |          | 1     | Force the interrupt                         |
| 2   | PHE      |       | Force quadrature phase error interrupt      |
|     |          | 0     | No effect                                   |
|     |          | 1     | Force the interrupt                         |
| 1   | PCE      |       | Force position counter error interrupt      |
|     |          | 0     | No effect                                   |
|     |          | 1     | Force the interrupt                         |
| 0   | Reserved | 0 1   | Always write as 0                           |

# Table 5-21. eQEP Interrupt Force (QFRC) Register Field Descriptions (continued)

# Figure 5-40. eQEP Status (QEPSTS) Register

| 15       |      |     |      |       |       |       | 8    |
|----------|------|-----|------|-------|-------|-------|------|
| Reserved |      |     |      |       |       |       |      |
|          | R-0  |     |      |       |       |       |      |
| 7        | 6    | 5   | 4    | 3     | 2     | 1     | 0    |
| UPEVNT   | FIDF | QDF | QDLF | COEF  | CDEF  | FIMF  | PCEF |
| R/W-1    | R-0  | R-0 | R-0  | R/W-1 | R/W-1 | R/W-1 | R-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 5-22. eQEP Status (QEPSTS) Register Field Descriptions

| Bit  | Field    | Value | Description                                                                                                |
|------|----------|-------|------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved |       | Always write as 0                                                                                          |
| 7    | UPEVNT   |       | Unit position event flag                                                                                   |
|      |          | 0     | No unit position event detected                                                                            |
|      |          | 1     | Unit position event detected. Write 1 to clear.                                                            |
| 6    | FIDF     |       | Direction on the first index marker<br>Status of the direction is latched on the first index event marker. |
|      |          | 0     | Counter-clockwise rotation (or reverse movement) on the first index event                                  |
|      |          | 1     | Clockwise rotation (or forward movement) on the first index event                                          |

EXAS UMENTS

www.ti.com

| Bit | Field | Value | Description                                                                                  |
|-----|-------|-------|----------------------------------------------------------------------------------------------|
| 5   | QDF   |       | Quadrature direction flag                                                                    |
|     |       | 0     | Counter-clockwise rotation (or reverse movement)                                             |
|     |       | 1     | Clockwise rotation (or forward movement)                                                     |
| 4   | QDLF  |       | eQEP direction latch flag<br>Status of direction is latched on every index event marker.     |
|     |       | 0     | Counter-clockwise rotation (or reverse movement) on index event marker                       |
|     |       | 1     | Clockwise rotation (or forward movement) on index event marker                               |
| 3   | COEF  |       | Capture overflow error flag                                                                  |
|     |       | 0     | Sticky bit, cleared by writing 1                                                             |
|     |       | 1     | Overflow occurred in eQEP Capture timer (QEPCTMR)                                            |
| 2   | CDEF  |       | Capture direction error flag                                                                 |
|     |       | 0     | Sticky bit, cleared by writing 1                                                             |
|     |       | 1     | Direction change occurred between the capture position event.                                |
| 1   | FIMF  |       | First index marker flag                                                                      |
|     |       | 0     | Sticky bit, cleared by writing 1                                                             |
|     |       | 1     | Set by first occurrence of index pulse                                                       |
| 0   | PCEF  |       | Position counter error flag. This bit is not sticky and it is updated for every index event. |
|     |       | 0     | No error occurred during the last index transition.                                          |
|     |       | 1     | Position counter error                                                                       |

# Table 5-22. eQEP Status (QEPSTS) Register Field Descriptions (continued)

#### Figure 5-41. eQEP Capture Timer (QCTMR) Register

| 15 |       | 0 |
|----|-------|---|
|    | QCTMR |   |
|    | R/W   |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 5-23. eQEP Capture Timer (QCTMR) Register Field Descriptions

| Bits | Name  | Description                                             |
|------|-------|---------------------------------------------------------|
| 15-0 | QCTMR | This register provides time base for edge capture unit. |

# Figure 5-42. eQEP Capture Period (QCPRD) Register

15

| 0     |  |
|-------|--|
| QCPRD |  |
| R/W   |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 5-24. eQEP Capture Period Register (QCPRD) Register Field Descriptions

| Bits | Name  | Description                                                                                 |
|------|-------|---------------------------------------------------------------------------------------------|
| 15-0 | QCPRD | This register holds the period count value between the last successive eQEP position events |

# 15

Figure 5-43. eQEP Capture Timer Latch (QCTMRLAT) Register

QCTMRLAT

R

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

0



ſ

#### www.ti.com

# Table 5-25. eQEP Capture Timer Latch (QCTMRLAT) Register Field Descriptions

| Bits | Name | Description                                                                                                                               |
|------|------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 |      | The eQEP capture timer value can be latched into this register on two events viz., unit timeout event, reading the eQEP position counter. |

# Figure 5-44. eQEP Capture Period Latch (QCPRDLAT) Register

| 15       | 0 |
|----------|---|
| QCPRDLAT |   |
| R/W      |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 5-26. eQEP Capture Period Latch (QCPRDLAT) Register Field Descriptions

| Bits | Name     | Description                                                                                                                            |  |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------|--|
| 15-0 | QCPRDLAT | eQEP capture period value can be latched into this register on two events viz., unit timeout event, reading the eQEP position counter. |  |



. .

# Analog-to-Digital Converter and Comparator

The ADC module described in this reference guide is a Type 3 ADC and exists on the Piccolo<sup>TM</sup> family of devices. The Comparator function described in this reference guide is a Type 0 Comparator. See the *TMS320C28xx, 28xxx DSP Peripheral Reference Guide* (SPRU566) for a list of all devices with modules of the same type, to determine the differences between the types, and for a list of device-specific differences within a type.

| Горіс |                                   | Page |  |
|-------|-----------------------------------|------|--|
| 6.1   | Analog-to-Digital Converter (ADC) | 442  |  |

# 6.1 Analog-to-Digital Converter (ADC)

The ADC module described in this reference guide is a 12-bit recyclic ADC; part SAR, part pipelined. The analog circuits of this converter, referred to as the "core" in this document, include the front-end analog multiplexers (MUXs), sample-and-hold (S/H) circuits, the conversion core, voltage regulators, and other analog supporting circuits. Digital circuits, referred to as the "wrapper" in this document, include programmable conversions, result registers, interface to analog circuits, interface to device peripheral bus, and interface to other on-chip modules.

# 6.1.1 Features

The core of the ADC contains a single 12-bit converter fed by two sample and hold circuits. The sample and hold circuits can be sampled simultaneously or sequentially. These, in turn, are fed by a total of up to 16 analog input channels. See the device data manual for the specific number of channels available. The converter can be configured to run with an internal bandgap reference to create true-voltage based conversions or with a pair of external voltage references (VREFHI/LO) to create ratiometric based conversions.

Contrary to previous ADC types, this ADC is not sequencer-based. It is easy for the user to create a series of conversions from a single trigger. However, the basic principle of operation is centered around the configurations of individual conversions, called SOC's, or start-of-conversions.

Functions of the ADC module include:

- 12-bit ADC core with built-in dual sample-and-hold (S/H)
- Simultaneous sampling or sequential sampling modes
- Full range analog input: 0 V to 3.3 V fixed, or VREFHI/VREFLO ratiometric
- · Runs at full system clock, no prescaling required
- Up to 16-channel, multiplexed inputs
- 16 SOC's, configurable for trigger, sample window, and channel
- 16 result registers (individually addressable) to store conversion values
- Multiple trigger sources
  - S/W software immediate start
  - ePWM 1-8
  - GPIO XINT2
  - CPU Timers 0/1/2
  - ADCINT1/2
- 9 flexible PIE interrupts, can configure interrupt request after any conversion

# 6.1.2 Block Diagram

Figure 6-1 shows the block diagram of the ADC module.





Figure 6-1. ADC Block Diagram

# 6.1.3 SOC Principle of Operation

Contrary to previous ADC types, this ADC is not sequencer based. Instead, it is SOC-based. The term SOC is a configuration set defining the single conversion of a single channel. In that set there are three configurations: the trigger source that starts the conversion, the channel to convert, and the acquisition (sample) window size. Each SOC is independently configured and can have any combination of the trigger, channel, and sample window size available. Multiple SOCs can be configured for the same trigger, channel, and/or acquisition window as desired. This provides a very flexible means of configurating conversions ranging from individual samples of different channels with different triggers, to oversampling the same channel using a single trigger, to creating your own series of conversions of different channels all from a single trigger.

The trigger source for SOCx is configured by a combination of the TRIGSEL field in the ADCSOCxCTL register and the appropriate bits in the ADCINTSOCSEL1 or ADCINTSOCSEL2 register. Software can also force an SOC event with the ADCSOCFRC1 register. The channel and sample window size for SOCx are configured with the CHSEL and ACQPS fields of the ADCSOCxCTL register.



Figure 6-2. SOC Block Diagram

For example, to configure a single conversion on channel ADCINA2 to occur when the ePWM3 timer reaches its period match, you must first set up ePWM3 to output an SOCA or SOCB signal on a period match. See the *Enhanced Pulse Width Modulator Module* chapter on how to do this. In this case, we will use SOCA. Then, set up one of the SOCs using its ADCSOCxCTL register. It makes no difference which SOC we choose, so we will use SOC0. The fastest allowable sample window for the ADC is 10 cycles. Choosing the fastest time for the sample window, channel ADCINA1 for the channel to convert, and ePWM3 for the SOC0 trigger, we will set the ACQPS field to 9, the CHSEL field to 2, and the TRIGSEL field to 9, respectively. The resulting value written into the register will be:

ADCSOC0CTL = 4889h;

// (ACQPS=9, CHSEL=2, TRIGSEL=9)

When configured as such, a single conversion of ADCINA2 will be started on an ePWM3 SOCA event with the resulting value stored in the ADCRESULT0 register.

If instead ADCINA2 needed to be oversampled by 3x, then SOC1, SOC2, and SOC3 could all be given the same configuration as SOC0.

| ADCSOC1CTL = 4889h; | // (ACQPS=9, CHSEL=2, TRIGSEL=9) |
|---------------------|----------------------------------|
| ADCSOC2CTL = 4889h; | // (ACQPS=9, CHSEL=2, TRIGSEL=9) |
| ADCSOC3CTL = 4889h; | // (ACQPS=9, CHSEL=2, TRIGSEL=9) |

When configured as such, four conversions of ADCINA2 will be started in series on an ePWM3 SOCA event with the resulting values stored in the ADCRESULT0 – ADCRESULT3 registers.

Another application may require three different signals to be sampled from the same trigger. This can be done by simply changing the CHSEL field for SOC0-SOC2 while leaving the TRIGSEL field unchanged.



ADCSOC0CTL = 4889h; ADCSOC1CTL = 4909h; ADCSOC2CTL = 4949h; // (ACQPS=9, **CHSEL=2**, *TRIGSEL=9*) // (ACQPS=9, **CHSEL=4**, *TRIGSEL=9*) // (ACQPS=9, **CHSEL=5**, *TRIGSEL=9*)

When configured this way, three conversions will be started in series on an ePWM3 SOCA event. The result of the conversion on channel ADCINA2 will show up in ADCRESULT0. The result of the conversion on channel ADCINA4 will show up in ADCRESULT1. The result of the conversion on channel ADCINA5 will show up in ADCRESULT2. The channel converted and the trigger have no bearing on where the result of the conversion shows up. The RESULT register is associated with the SOC.

**NOTE:** These examples are incomplete. Clocks must be enabled via the PCLKCR0 register and the ADC must be powered to work correctly. For a description of the PCLKCR0 register see the *System Control and Interrupts* chapter. For the power up sequence of the ADC, see Section 6.1.7. The CLKDIV2EN bit in the ADCCTL2 register must also be set to a proper value to obtain correct frequency of operation. For more information on the ADCCTL2 register please refer to Section 6.1.3.1.

#### 6.1.3.1 ADC Acquisition (Sample and Hold) Window

External drivers vary in their ability to drive an analog signal quickly and effectively. Some circuits require longer times to properly transfer the charge into the sampling capacitor of an ADC. To address this, the ADC supports control over the sample window length for each individual SOC configuration. Each ADCSOCxCTL register has a 6-bit field, ACQPS, that determines the sample and hold (S/H) window size. The value written to this field is one less than the number of cycles desired for the sampling window for that SOC. Thus, a value of 15 in this field will give 16 clock cycles of sample time. The minimum number of sample cycles allowed is 10 (ACQPS=9). The total sampling time is found by adding the sample window size to the conversion time of the ADC, 13 ADC clocks. Examples of various sample times are shown below in Table 6-1.

| ADC Clock | ACQPS | Sample Window | Conversion Time (13 cycles) | Total Time to Process<br>Analog Voltage <sup>(1)</sup> |  |
|-----------|-------|---------------|-----------------------------|--------------------------------------------------------|--|
| 30MHz     | 9     | 33.33ns       | 433.33ns                    | 666.67ns                                               |  |
| 30MHz     | 13    | 466.67ns      | 433.33ns                    | 900ns                                                  |  |
| 60MHz     | 9     | 166.67ns      | 216.67ns                    | 383.33ns                                               |  |
| 60MHz     | 13    | 233.33ns      | 216.67ns                    | 450ns                                                  |  |

#### Table 6-1. Sample Timings with Different Values of ACQPS

<sup>(1)</sup> The total times are for a single conversion and do not include pipelining effects that increase the average speed over time.



As shown in Figure 6-3, the ADCIN pins can be modeled as an RC circuit. With VREFLO connected to ground, a voltage swing from 0 to 3.3v on ADCIN yields a typical RC time constant of 2ns.



Typical Values of the Input Circuit Components:

Switch Resistance ( $R_{on}$ ): 3.4 k $\Omega$ Sampling Capacitor ( $C_h$ ): 1.6 pF Parasitic Capacitance ( $C_p$ ): 5 pF Source Resistance ( $R_s$ ): 50  $\Omega$ 

#### 6.1.3.2 Trigger Operation

Each SOC can be configured to start on one of many input triggers. Multiple SOCs can be configured for the same channel if desired. Following is a list of the available input triggers:

- Software
- CPU Timers 0/1/2 interrupts
- XINT2 SOC
- ePWM1-8 SOCA and SOCB

See the ADCSOCxCTL register bit definitions for the configuration details of these triggers.

Additionally ADCINT1 and ADCINT2 can be fed back to trigger another conversion. This configuration is controlled in the ADCINTSOCSEL1/2 registers. This mode is useful if a continuous stream of conversions is desired. See Section 6.1.10.3 for information on the ADC interrupt signals.

#### 6.1.3.3 Channel Selection

Each SOC can be configured to convert any of the available ADCIN input channels. When an SOC is configured for sequential sampling mode, the four bit CHSEL field of the ADCSOCxCTL register defines which channel to convert. When an SOC is configured for simultaneous sampling mode, the most significant bit of the CHSEL field is dropped and the lower three bits determine which pair of channels are converted.

ADCINA0 is shared with VREFHI, and therefore cannot be used as a variable input source when using external reference voltage mode. See Section 6.1.9 for details on this mode.

#### 6.1.3.4 ONESHOT Single Conversion Support

This mode will allow you to perform a single conversion on the next triggered SOC in the round robin scheme. The ONESHOT mode is only valid for channels present in the round robin wheel. Channels which are not configured for triggered SOC in the round robin scheme will get priority based on contents of the SOCPRIORITY field in the ADCSOCPRIORITYCTL register.







The effect of ONESHOT mode on sequential mode and simultaneous mode is explained below.

**Sequential mode:** Only the next active SOC in RR mode (one up from current RR pointer) will be allowed to generate SOC; all other triggers for other SOC slots will be ignored.

**Simultaneous mode:** If current RR pointer has SOC with simultaneous enabled; active SOC will be incremented by 2 from the current RR pointer. This is because simultaneous mode will create result for SOCx and SOCx+1, and SOCx+1 will never be triggered by the user.

**NOTE:** ONESHOT = 1 and SOCPRIORITY = 11111 is not a valid combination for above implementation reasons. This should not be a desired mode of operation by the user in any case. The limitation of the above is that the next SOCs must eventually be triggered, or else the ADC will not generate new SOCs for other out-of-order triggers. Any non-orthogonal channels should be placed in the priority mode which is unaffected by ONESHOT mode

# 6.1.4 ADC Conversion Priority

When multiple SOC flags are set at the same time, one of two forms of priority determines the order in which they are converted. The default priority method is round robin. In this scheme, no SOC has an inherent higher priority than another. Priority depends on the round robin pointer (RRPOINTER). The RRPOINTER reflected in the ADCSOCPRIORITYCTL register points to the last SOC converted. The highest priority SOC is given to the next value greater than the RRPOINTER value, wrapping around back to SOC0 after SOC15. At reset, the value is 32 since 0 indicates a conversion has already occurred. When RRPOINTER equals 32 the highest priority is given to SOC0. The RRPOINTER is reset by a device reset, when the ADCCTL1.RESET bit is set, or when the SOCPRICTL register is written.

An example of the round robin priority method is given in Figure 6-5.

# Figure 6-5. Round Robin Priority Example

Α

soc

0

RRPOINTER

soc

15

SOC

14

13

- A After reset, SOC0 is highest priority SOC ; SOC7 receives trigger; SOC7 configured channel is converted immediately.
- в RRPOINTER changes to point to SOC 7; SOC8 is now highest priority SOC .
- C SOC2 & SOC12 triggers rcvd. simultaneously; SOC12 is first on round robin wheel; SOC12 configured channel is converted while SOC2 stays pending.
- RRPOINTER changes to point to SOC 12; D
- E RRPOINTER changes to point to SOC 2; SOC3 is now highest priority SOC .



The SOCPRIORITY field in the ADCSOCPRIORITYCTL register can be used to assign high priority from a single to all of the SOCs. When configured as high priority, an SOC will interrupt the round robin wheel after any current conversion completes and insert itself in as the next conversion. After its conversion completes, the round robin wheel will continue where it was interrupted. If two high priority SOCs are triggered at the same time, the SOC with the lower number will take precedence.



High priority mode is assigned first to SOC0, then in increasing numerical order. The value written in the SOCPRIORITY field defines the first SOC that is not high priority. In other words, if a value of 4 is written into SOCPRIORITY, then SOC0, SOC1, SOC2, and SOC3 are defined as high priority, with SOC0 the highest.

An example using high priority SOCs is given in Figure 6-6.

# Figure 6-6. High Priority Example



# 6.1.5 Simultaneous Sampling Mode

In some applications it is important to keep the delay between the sampling of two signals minimal. The ADC contains dual sample and hold circuits to allow two different channels to be sampled simultaneously. Simultaneous sampling mode is configured for a pair of SOCx's with the ADCSAMPLEMODE register. The even numbered SOCx and the following odd numbered SOCx (i.e., SOC0 and SOC1) are coupled together with one enable bit (SIMULEN0, in this case). The coupling behavior is as follows:

- Either SOCx's trigger will start a pair of conversions.
- The pair of channels converted will consist of the A-channel and the B-channel corresponding to the value of the CHSEL field of the triggered SOCx. The valid values in this mode are 0-7.
- Both channels will be sampled simultaneously.
- The A channel will always convert first.
- The even EOCx pulse will be generated based off of the A-channel conversion, the odd EOCx pulse will be generated off of the B-channel conversion. See Section 1.6 for an explanation of the EOCx signals.
- The result of the A-channel conversion is placed in the even ADCRESULTx register and the result of the B-channel conversion is written to the odd ADCRESULTx register.

For example, if the ADCSAMPLEMODE.SIMULEN0 bit is set, and SOC0 is configured as follows:

CHSEL = 2 (ADCINA2/ADCINB2 pair)

#### TRIGSEL = 5 (ADCTRIG5 = ePWM1.ADCSOCA)

When the ePWM1 sends out an ADCSOCA trigger, both ADCINA2 and ADCINB2 will be sampled simultaneously (assuming priority). Immediately after, the ADCINA2 channel will be converted and its value will be stored in the ADCRESULT0 register. Depending on the ADCCTL1.INTPULSEPOS setting, the EOC0 pulse will either occur when the conversion of ADCINA2 begins or completes. Then the ADCINB2 channel will be converted and its value will be stored in the ADCRESULT1 register. Depending on the ADCRESULT1 register. Depending on the ADCCTL1.INTPULSEPOS setting, the EOC1 pulse will either occur when the conversion of ADCINB2 begins or completes.

Typically in an application it is expected that only the even SOCx of the pair will be used. However, it is possible to use the odd SOCx instead, or even both. In the latter case, both SOCx triggers will start a conversion. Therefore, caution is urged as both SOCx's will store their results to the same ADCRESULTx registers, possibly overwriting each other.

The rules of priority for the SOCx's remain the same as in sequential sampling mode.

Section 6.1.11 shows the timing of simultaneous sampling mode.

# 6.1.6 EOC and Interrupt Operation

Just as there are 16 independent SOCx configuration sets, there are 16 EOCx pulses. In sequential sampling mode, the EOCx is associated directly with the SOCx. In simultaneous sampling mode, the even and the following odd EOCx pair are associated with the even and the following odd SOCx pair, as described in Section 6.1.5. Depending on the ADCCTL1.INTPULSEPOS setting, the EOCx pulse will occur either at the beginning of a conversion or the end. See Section 6.1.6 for exact timings on the EOCx pulses.

The ADC contains 9 interrupts that can be flagged and/or passed on to the PIE. Each of these interrupts can be configured to accept any of the available EOCx signals as its source. The configuration of which EOCx is the source is done in the INTSELxNy registers. Additionally, the ADCINT1 and ADCINT2 signals can be configured to generate an SOCx trigger. This is beneficial to creating a continuous stream of conversions.

Figure 6-7 shows a block diagram of the interrupt structure of the ADC.





#### Figure 6-7. Interrupt Structure

# 6.1.7 Power Up Sequence

The ADC resets to the ADC off state. Before writing to any of the ADC registers the ADCENCLK bit in the PCLKCR0 register must be set. For a description of the PCLKCR0 register see the *System Control and Interrupts* chapter. When powering up the ADC, use the following sequence:

- 1. If an external reference is desired, enable this mode using bit 3 (ADCREFSEL) in the ADCCTL1 register.
- 2. Power up the reference, bandgap, and analog circuits together by setting bits 7-5 (ADCPWDN, ADCBGPWD, ADCREFPWD) in the ADCCTL1 register.
- 3. Enable the ADC by setting bit 14 (ADCENABLE) of the ADCCTL1 register.
- 4. Before performing the first conversion, a delay of 1 millisecond after step 2 is required.

Alternatively, steps 1 through 3 can be performed simultaneously.

When powering down the ADC, all three bits in step 2 can be cleared simultaneously. The ADC power levels must be controlled via software and they are independent of the state of the device power modes.

**NOTE:** This type ADC requires a 1ms delay after all of the circuits are powered up. This differs from the previous type ADCs.

# 6.1.8 ADC Calibration

Inherent in any converter is a zero offset error and a full scale gain error. The ADC is factory-calibrated at 25 degrees Celsius to correct both of these while allowing the user to modify the offset correction for any application environmental effects, such as the ambient temperature. Except under certain emulation conditions, or unless a modification from the factory settings is desired, the user is not required to perform any specific action. The ADC will be properly calibrated during the device boot process.

**NOTE:** If the system is reset or the ADC module is reset using Bit 15 (RESET) from the ADC Control Register 1, the Device\_cal() routine must be repeated.



#### 6.1.8.1 Factory Settings and Calibration Function

During the fabrication and test process Texas Instruments calibrates several ADC settings along with a couple of internal oscillator settings. These settings are embedded into the TI reserved OTP memory as part of a C-callable function named Device\_cal(). Called during the startup boot procedure in the Boot ROM this function writes the factory settings into their respective active registers. Until this occurs, the ADC and the internal oscillators will not adhere to their specified parameters. If the boot process is skipped during emulation, the user must ensure the trim settings are written to their respective registers to ensure the ADC and the internal oscillators meet the specifications in the datasheet. This can be done either by calling this function manually or in the application itself, or by a direct write via CCS. A gel function is provided as part of the C/C++ Header Files and Peripheral Examples (SPRC823) to accomplish this.

For more information on the Device\_cal() function refer to the ROM Code and Peripheral Booting chapter.

Texas Instruments cannot guarantee the parameters specified in the datasheet if a value other than the factory settings contained in the TI reserved OTP memory is written into the ADC trim registers.

#### 6.1.8.2 ADC Zero Offset Calibration

Zero offset error is defined as the resultant digital value that occurs when converting a voltage at VREFLO. This base error affects all conversions of the ADC and together with the full scale gain and linearity specifications, determine the DC accuracy of a converter. The zero offset error can be positive, meaning that a positive digital value is output when VREFLO is presented, or negative, meaning that a voltage higher than a one step above VREFLO still reads as a digital zero value. To correct this error, the two's complement of the error is written into the ADCOFFTRIM register. The value contained in this register will be applied before the results are available in the ADC result registers. This operation is fully contained within the ADC core, so the timing for the results will not be affected and the full dynamic range of the ADC will be maintained for any trim value. Calling the Device\_cal() function writes the ADCOFFTRIM register to compensate for additional offset error induced by the application environment. This can be done without sacrificing an ADC channel by using the VREFLOCONV bit in the ADCCTRL1 register.

Use the following procedure to re-calibrate the ADC offset:

- 1. Set ADCOFFTRIM to 80 (50h). This adds an artificial offset to account for negative offset that may reside in the ADC core.
- 2. Set ADCCTL1.VREFLOCONV to 1. This internally connects VREFLO to input channel B5. See the ADCCTL1 register description for more details.
- 3. Perform multiple conversions on B5 (i.e. sample VREFLO) and take an average to account for board noise. See Section 6.1.3 on how to set up and initiate the ADC to sample B5.
- 4. Set ADCOFFTRIM to 80 (50h) minus the average obtained in step 3. This removes the artificial offset from step 1 and creates a two's complement of the offset error.
- 5. Set ADCCTL1.VREFLOCONV to 0. This connects B5 back to the external ADCINB5 input pin.

**NOTE:** The "AdcOffsetSelfCal()" function located in F2805x\_Adc.c in the common header files performs these steps.

#### 6.1.8.3 ADC Full Scale Gain Calibration

Gain error occurs as an incremental error as the voltage input is increased. Full scale gain error occurs at the maximum input voltage. As in offset error, gain error can be positive or negative. A positive full scale gain error means that the full scale digital result is reached before the maximum voltage is input. A negative full scale error implies that the full digital result will never be achieved. The calibration function Device\_cal() writes a factory trim value to correct the ADC full scale gain error into the ADCREFTRIM register. This register should not be modified after the Device\_cal() function is called.

#### 6.1.8.4 ADC Bias Current Calibration

To further increase the accuracy of the ADC, the calibration function Device\_cal() also writes a factory trim value to an ADC register for the ADC bias currents. This register should not be modified after the Device\_cal() function is called.

# 6.1.9 Internal/External Reference Voltage Selection

# 6.1.9.1 Internal Reference Voltage

The ADC can operate in two different reference modes, selected by the ADCCTL1.ADCREFSEL bit. By default the internal bandgap is chosen to generate the reference voltage for the ADC. This will convert the voltage presented according to a fixed scale 0 to 3.3v range. The equation governing conversions in this mode is:

Digital Value = 0 Digital Value = 4096 [(Input – VREFLO)/3.3v] Digital Value = 4095, \*All fractional values are truncated when Input  $\leq 0v$ when 0v <Input < 3.3vwhen Input  $\geq 3.3v$ 

\*\*VREFLO must be tied to ground in this mode. This is done internally on some devices.

# 6.1.9.2 External Reference Voltage

To convert the voltage presented as a ratiometric signal, the external VREFHI/VREFLO pins should be chosen to generate the reference voltage. In contrast with the fixed 0 to 3.3v input range of the internal bandgap mode, the ratiometric mode has an input range from VREFLO to VREFHI. Converted values will scale to this range. For instance, if VREFLO is set to 0.5v and VREFHI is 3.0v, a voltage of 1.75v will be converted to the digital result of 2048. See the device datasheet for the allowable ranges of VREFLO and VREFHI. On some devices VREFLO is tied to ground internally, and hence limited to 0v. The equation governing the conversions in this mode is:

Digital Value = 0 Digital Value = 4096 [(Input – VREFLO)/(VREFHI – VREFLO)] Digital Value = 4095, \*All fractional values are truncated when Input ≤ VREFLO when VREFLO < Input < VREFHI when Input ≥ VREFHI



#### 6.1.10 ADC Registers

This section contains the ADC registers and bit definitions with the registers grouped by function. All of the ADC registers are located in Peripheral Frame 2 except the ADCRESULTx registers, which are found in Peripheral Frame 0. See the device data manual for specific addresses.

| Table 6-2. ADC Configuration & Control R | Registers (AdcRegs and AdcResult): |
|------------------------------------------|------------------------------------|
|------------------------------------------|------------------------------------|

| Register Name            | Address Offset             | Size<br>(x16) | Description                                                                     |
|--------------------------|----------------------------|---------------|---------------------------------------------------------------------------------|
| ADCCTL1                  | 0x00                       | 1             | Control 1 Register <sup>(1)</sup>                                               |
| ADCCTL2                  | 0x01                       | 1             | Control 2 Register (1)                                                          |
| ADCINTFLG                | 0x04                       | 1             | Interrupt Flag Register                                                         |
| ADCINTFLGCLR             | 0x05                       | 1             | Interrupt Flag Clear Register                                                   |
| ADCINTOVF                | 0x06                       | 1             | Interrupt Overflow Register                                                     |
| ADCINTOVFCLR             | 0x07                       | 1             | Interrupt Overflow Clear Register                                               |
| INTSEL1N2                | 0x08                       | 1             | Interrupt 1 and 2 Selection Register <sup>(1)</sup>                             |
| INTSEL3N4                | 0x09                       | 1             | Interrupt 3 and 4 Selection Register <sup>(1)</sup>                             |
| INTSEL5N6                | 0x0A                       | 1             | Interrupt 5 and 6 Selection Register <sup>(1)</sup>                             |
| INTSEL7N8                | 0x0B                       | 1             | Interrupt 7 and 8 Selection Register <sup>(1)</sup>                             |
| INTSEL9N10               | 0x0C                       | 1             | Interrupt 9 Selection Register (reserved Interrupt 10 Selection) <sup>(1)</sup> |
| SOCPRICTL                | 0x10                       | 1             | SOC Priority Control Register <sup>(1)</sup>                                    |
| ADCSAMPLEMODE            | 0x12                       | 1             | Sampling Mode Register <sup>(1)</sup>                                           |
| ADCINTSOCSEL1            | 0x14                       | 1             | Interrupt SOC Selection 1 Register (for 8 channels) <sup>(1)</sup>              |
| ADCINTSOCSEL2            | 0x15                       | 1             | Interrupt SOC Selection 2 Register (for 8 channels) <sup>(1)</sup>              |
| ADCSOCFLG1               | 0x18                       | 1             | SOC Flag 1 Register (for 16 channels)                                           |
| ADCSOCFRC1               | 0x1A                       | 1             | SOC Force 1 Register (for 16 channels)                                          |
| ADCSOCOVF1               | 0x1C                       | 1             | SOC Overflow 1 Register (for 16 channels)                                       |
| ADCSOCOVFCLR1            | 0x1E                       | 1             | SOC Overflow Clear 1 Register (for 16 channels)                                 |
| ADCSOC0CTL - ADCSOC15CTL | 0x20 - 0x2F                | 1             | SOC0 Control Register to SOC15 Control Register <sup>(1)</sup>                  |
| ADCREFTRIM               | 0x40                       | 1             | Reference Trim Register <sup>(1)</sup>                                          |
| ADCOFFTRIM               | 0x41                       | 1             | Offset Trim Register <sup>(1)</sup>                                             |
| ADCREV – reserved        | 0x4F                       | 1             | Revision Register                                                               |
| ADCRESULT0 - ADCRESULT15 | 0x00 - 0x0F <sup>(2)</sup> | 1             | ADC Result 0 Register to ADC Result 15 Register                                 |

<sup>(1)</sup> This register is EALLOW protected.

<sup>(2)</sup> The base address of the ADCRESULT registers differs from the base address of the other ADC registers. In the header files, the ADCRESULT registers are found in the AdcResult register file, not AdcRegs.

#### 6.1.10.1 ADC Control Register 1 (ADCCTL1)

NOTE: The following ADC Control Register is EALLOW protected.

| 15      | 14        | 13        | 12       |           |             |                | 8        |  |
|---------|-----------|-----------|----------|-----------|-------------|----------------|----------|--|
| RESET   | ADCENABLE | ADCBSY    |          |           | ADCBSYCHN   |                |          |  |
| R-0/W-1 | R/W-0     | R-0       | R-0      |           |             |                |          |  |
| 7       | 6         | 5         | 4        | 3         | 2           | 1              | 0        |  |
| ADCPWDN | ADCBGPWD  | ADCREFPWD | Reserved | ADCREFSEL | INTPULSEPOS | VREFLO<br>CONV | TEMPCONV |  |
| R/W-0   | R/W-0     | R/W-0     | R-0      | R/W-0     | R/W-0       | R/W-0          | R/W-0    |  |

LEGEND: R/W = Read/Write; R = Read only; R-0/W-1 = always read as 0, write 1 to set; -n = value after reset



# Table 6-3. ADC Control Register 1 (ADCCTL1) Field Descriptions

| Bit  | Field     | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | RESET     |       | ADC module software reset. This bit causes a master reset on the entire ADC module. All register bits<br>and state machines are reset to the initial state as occurs when the device reset pin is pulled low (or<br>after a power-on reset). This is a one-time-effect bit, meaning this bit is self-cleared immediately after it<br>is set to 1. Read of this bit always returns a 0. Also, the reset of ADC has a latency of two clock cycles<br>(that is, other ADC control register bits should not be modified until two clock cycles after the instruction<br>that resets the ADC. |
|      |           | 0     | No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      |           | 1     | Resets entire ADC module (bit is then set back to 0 by ADC logic)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      |           |       | <b>Note</b> : The ADC module is reset during a system reset. If an ADC module reset is desired at any other time, you can do so by writing a 1 to this bit. After two clock cycles, you can then write the appropriate values to the ADCCTL1 register bits. Assembly code:                                                                                                                                                                                                                                                                                                               |
|      |           |       | MOV ADCCTL1, #1xxxxxxxxxxxx ; Resets the ADC (RESET = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|      |           |       | NOP ; Delay two cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|      |           |       | NOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|      |           |       | MOV ADCCTL1, #0xxxxxxxxxxxxxxxxx ; Set to user-desired value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|      |           |       | <b>Note</b> : The second MOV is not required if the default configuration is sufficient.<br><b>Note</b> : If the system is reset or the ADC module is reset using Bit 15 (RESET) from the ADC Control Register 1, the Device_cal() routine must be repeated.                                                                                                                                                                                                                                                                                                                             |
| 14   | ADCENABLE |       | ADC Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |           | 0     | ADC disabled (does not power down ADC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|      |           | 1     | ADC Enabled. Musts set before an ADC conversion (recommend that it be set directly after setting ADC power-up bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13   | ADCBSY    |       | ADC Busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|      |           |       | Set when ADC SOC is generated, cleared per below. Used by the ADC state machine to determine if ADC is available to sample.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|      |           |       | Sequential Mode: Cleared 4 ADC clocks after negative edge of S/H pulse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|      |           |       | Simultaneous Mode: Cleared 14 ADC clocks after negative edge of S/H pulse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      |           | 0     | ADC is available to sample next channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |           | 1     | ADC is busy and cannot sample another channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12-8 | ADCBSYCHN |       | Set when ADC SOC for current channel is generated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      |           |       | When ADCBSY = 0: holds the value of the last converted channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|      |           |       | When ADCBSY = 1: reflects channel currently being processed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|      |           | 00h   | ADCINA0 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 01h   | ADCINA1 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 02h   | ADCINA2 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 03h   | ADCINA3 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 04h   | ADCINA4 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 05h   | ADCINA5 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 06h   | ADCINA6 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 07h   | ADCINA7 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 08h   | ADCINB0 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 09h   | ADCINB1 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 0Ah   | ADCINB2 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 0Bh   | ADCINB3 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 0Ch   | ADCINB4 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 0Dh   | ADCINB5 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 0Eh   | ADCINB6 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 0Fh   | ADCINB7 is currently processing or was last channel converted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |           | 1xh   | Invalid value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



| Bit | Field       | Value | Description                                                                                                                                                                                                                                                                                                   |
|-----|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ADCPWDN     |       | ADC power down (active low).                                                                                                                                                                                                                                                                                  |
|     |             |       | This bit controls the power up and power down of all the analog circuitry inside the analog core except the bandgap and reference circuitry                                                                                                                                                                   |
|     |             | 0     | All analog circuitry inside the core except the bandgap and referencce circuitry is powered down                                                                                                                                                                                                              |
|     |             | 1     | The analog circuitry inside the core is powered up                                                                                                                                                                                                                                                            |
| 6   | ADCBGPWD    |       | Bandgap circuit power down (active low)                                                                                                                                                                                                                                                                       |
|     |             | 0     | Bandgap circuitry is powered down                                                                                                                                                                                                                                                                             |
|     |             | 1     | Bandgap buffer's curcuitry inside core is powered up                                                                                                                                                                                                                                                          |
| 5   | ADCREFPWD   |       | Reference buffers circuit power down (active low)                                                                                                                                                                                                                                                             |
|     |             | 0     | Reference buffers circuitry is powered down                                                                                                                                                                                                                                                                   |
|     |             | 1     | Reference buffers circuitry inside the core is powered up                                                                                                                                                                                                                                                     |
| 4   | Reserved    |       | Reads return a zero; Writes have no effect.                                                                                                                                                                                                                                                                   |
| 3   | ADCREFSEL   |       | Internal/external reference select                                                                                                                                                                                                                                                                            |
|     |             | 0     | Internal Bandgap used for reference generation                                                                                                                                                                                                                                                                |
|     |             | 1     | External VREFHI/VREFLO pins used for reference generation. On some devices the VREFHI pin is shared with ADCINA0. In this case ADCINA0 will not be available for conversions in this mode. On some devices the VREFLO pin is shared with VSSA. In this case the VREFLO voltage cannot be varied.              |
| 2   | INTPULSEPOS |       | INT Pulse Generation control                                                                                                                                                                                                                                                                                  |
|     |             | 0     | INT pulse generation occurs when ADC begins conversion (neg edge of sample pulse od the sampled signal)                                                                                                                                                                                                       |
|     |             | 1     | INT pulse generation occurs 1 cycle prior to ADC result latching into its result register                                                                                                                                                                                                                     |
| 1   | VREFLOCONV  |       | VREFLO Convert.                                                                                                                                                                                                                                                                                               |
|     |             |       | When enabled, internally connects VREFLO to the ADC channel B5 and disconnects the ADCINB5 pin from the ADC. Whether the pin ADCINB5 exists on the device does not affect this function. Any external circuitry on the ADCINB5 pin is unaffected by this mode.                                                |
|     |             | 0     | ADCINB5 is passed to the ADC module as normal, VREFLO connection to ADCINB5 is disabled                                                                                                                                                                                                                       |
|     |             | 1     | VREFLO internally connected to the ADC for sampling                                                                                                                                                                                                                                                           |
| 0   | TEMPCONV    |       | Temperature sensor convert. When enabled internally connects the internal temperature sensor to ADC channel A5 and disconnects the ADCINA5 pin from the ADC. Whether the pin ADCINA5 exists on the device does not affect this function. Any external circuitry on the ADCINA5 pin is uneffected by this mode |
|     |             | 0     | ADCINA5 is passed to the ADC module as normal, internal temperature sensor connection to ADCINA5 is disabled.                                                                                                                                                                                                 |
|     |             | 1     | Temperature sensor is internally connected to the ADC for sampling                                                                                                                                                                                                                                            |

# Table 6-3. ADC Control Register 1 (ADCCTL1) Field Descriptions (continued)

# 6.1.10.2 ADC Control Register 2 (ADCCTL2)

**NOTE:** The following ADC Control Register is EALLOW protected.

# Figure 6-9. ADC Control Register 2 (ADCCTL2) (Address Offset 01h)

| 15       | 3 | 2         | 1             | 0         |
|----------|---|-----------|---------------|-----------|
| Reserved |   | CLKDIV43N | ADCNONOVERLAP | CLKDIV2EN |
| R-0      |   | R/w-0     | R/W-0         | R/W-0     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



# Table 6-4. ADC Control Register 2 (ADCCTL2) Field Descriptions

| Bit  | Field         | Value | Description                                                                                                                                                  |  |  |  |
|------|---------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 15-2 | Reserved      |       | Reserved                                                                                                                                                     |  |  |  |
| 2    | CLKDIV43N     |       | When enabled, divides the ADC input clock by 4                                                                                                               |  |  |  |
|      |               | 0     | ADC clock = CPU clock                                                                                                                                        |  |  |  |
|      |               | 1     | ADC clock = CPU clock/4                                                                                                                                      |  |  |  |
| 1    | ADCNONOVERLAP |       | ADCNONOVERLAP control bit                                                                                                                                    |  |  |  |
|      |               | 0     | Overlap of sample and conversion is allowed                                                                                                                  |  |  |  |
|      |               | 1     | Overlap of sample is not allowed                                                                                                                             |  |  |  |
| 0    | CLKDIV2EN     |       | When enabled, divides the ADC input clock by 2. When running /2 ADCCLK, scale the minimum sample duration accordingly to meet 116.6ns for better throughput. |  |  |  |
|      |               | 0     | ADC clock = CPU clock                                                                                                                                        |  |  |  |
|      |               | 1     | ADC clock = CPU clock/2                                                                                                                                      |  |  |  |

# 6.1.10.3 ADC Interrupt Registers

# Figure 6-10. ADC Interrupt Flag Register (ADCINTFLG) (Address Offset 04h)

| 15      |         |         |          |         |         | 9       | 8       |
|---------|---------|---------|----------|---------|---------|---------|---------|
|         |         |         | Reserved |         |         |         | ADCINT9 |
|         |         |         | R-0      |         |         |         | R-0     |
| 7       | 6       | 5       | 4        | 3       | 2       | 1       | 0       |
| ADCINT8 | ADCINT7 | ADCINT6 | ADCINT5  | ADCINT4 | ADCINT3 | ADCINT2 | ADCINT1 |
| R-0     | R-0     | R-0     | R-0      | R-0     | R-0     | R-0     | R-0     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 6-5. ADC Interrupt Flag Register (ADCINTFLG) Field Descriptions

| Bit  | Field                              | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-9 | Reserved                           |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8-0  | 8-0 ADCINTx<br>(x = 9 to 1) 0<br>1 |       | ADC Interrupt Flag Bits: Reading this bit indicates if an ADCINT pulse was generated                                                                                                                                                                                                                                                                                                                                      |
|      |                                    |       | No ADC interrupt pulse generated                                                                                                                                                                                                                                                                                                                                                                                          |
|      |                                    |       | ADC Interrupt pulse generated                                                                                                                                                                                                                                                                                                                                                                                             |
|      |                                    |       | If the ADC interrupt is placed in continuous mode (INTSELxNy register) then further interrupt pulses are generated whenever a selected EOC event occurs even if the flag bit is set. If the continuous mode is not enabled, then no further interrupt pulses are generated until the user clears this flag bit using the ADCINTFLGCLR register. Rather, an ADC interrupt overflow event occurs in the ADCINTOVF register. |

# Figure 6-11. ADC Interrupt Flag Clear Register (ADCINTFLGCLR) (Address Offset 05h)

| 15      |          |         |         |         |         | 9       | 8       |  |  |  |
|---------|----------|---------|---------|---------|---------|---------|---------|--|--|--|
|         | Reserved |         |         |         |         |         |         |  |  |  |
|         |          |         | R-0     |         |         |         | W1C-0   |  |  |  |
| 7       | 6        | 5       | 4       | 3       | 2       | 1       | 0       |  |  |  |
| ADCINT8 | ADCINT7  | ADCINT6 | ADCINT5 | ADCINT4 | ADCINT3 | ADCINT2 | ADCINT1 |  |  |  |
| W1C-0   | W1C-0    | W1C-0   | W1C-0   | W1C-0   | W1C-0   | W1C-0   | W1C-0   |  |  |  |
|         |          |         |         |         |         |         |         |  |  |  |

LEGEND: W1C = Write 1 to clear bit, reads return 0; R = Read only; -n = value after reset



#### Analog-to-Digital Converter (ADC)

www.ti.com

# Table 6-6. ADC Interrupt Flag Clear Register (ADCINTFLGCLR) Field Descriptions

| Bit  | Field        | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|--------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-9 | Reserved     |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 8-0  | ADCINTx      |       | ADC interrupt Flag Clear Bit; Reads return 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|      | (x = 9 to 1) | 0     | No action.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      |              | 1     | If the ADC interrupt is placed in continuous mode (INTSELxNy register) then further interrupt pulses<br>are generated whenever a selected EOC event occurs even if the flag bit is set. If the continuous<br>mode is not enabled, then no further interrupt pulses are generated until the user clears this flag bit<br>using the ADCINTFLGCLR register. Rather, an ADC interrupt overflow event occurs in the<br>ADCINTOVF register.<br><b>Boundary condition for clearing/setting flag bits:</b> If hardware is trying to set bit while software<br>tries to clear the bit in the same cycle, the following will take place: |
|      |              |       | 1. SW has priority, and will clear the flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |              |       | 2. HW set will be discarded, no signal will propagate to the PIE form the latch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      |              |       | 3. Overflow flag/condition will be generated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

# Figure 6-12. ADC Interrupt Overflow Register (ADCINTOVF) (Address Offset 06h)

| 15      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |         |         | 9       | 8       |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|---------|---------|---------|
|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reserved |         |         |         | ADCINT9 |
|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R-0      |         |         |         | R-0     |
| 7       | 6               | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4        | 3       | 2       | 1       | 0       |
| ADCINT8 | ADCINT7         | ADCINT6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ADCINT5  | ADCINT4 | ADCINT3 | ADCINT2 | ADCINT1 |
| R-0     | R-0             | R-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R-0      | R-0     | R-0     | R-0     | R-0     |
|         | Des IAA/Steel D | Decident set of the se | -1       |         |         |         |         |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 6-7. ADC Interrupt Overflow Register (ADCINTOVF) Field Descriptions

| Bit  | Field        | Value | Description                                                                                                                                                                                    |
|------|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-9 | Reserved     |       | Reserved                                                                                                                                                                                       |
| 8-0  | ADCINTx      |       | ADC Interrupt Overflow Bits.                                                                                                                                                                   |
|      | (x = 9 to 1) |       | Indicates if an overflow occurred when generating ADCINT pulses. If the respective ADCINTFLG bit is set and a selected additional EOC trigger is generated, then an overflow condition occurs. |
|      |              | 0     | No ADC interrupt overflow event detected.                                                                                                                                                      |
|      |              | 1     | ADC Interrupt overflow event detected.                                                                                                                                                         |
|      |              |       | The overflow bit does not care about the continuous mode bit state. An overflow condition is generated irrespective of this mode selection.                                                    |

# Figure 6-13. ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) (Address Offset 07h)

| 15           |              |              |              |              |              | 9            | 8            |
|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
|              |              |              | Reserved     |              |              |              | ADCINT9      |
|              |              |              | R-0          |              |              |              | W1C-0        |
| 7            |              | _            |              |              | -            |              | _            |
| 1            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
| 7<br>ADCINT8 | 6<br>ADCINT7 | 5<br>ADCINT6 | 4<br>ADCINT5 | 3<br>ADCINT4 | 2<br>ADCINT3 | 1<br>ADCINT2 | 0<br>ADCINT1 |

LEGEND: W1C = Write 1 to clear bit, reads return 0; R = Read only; -n = value after reset

| Bit  | Field        | Value | Description                                                                                                                                                                                                                                                  |
|------|--------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-9 | Reserved     |       | Reserved                                                                                                                                                                                                                                                     |
| 8-0  | ADCINTx      |       | ADC Interrupt Overflow Clear Bits; Reads return 0                                                                                                                                                                                                            |
|      | (x = 9 to 1) | 0     | No action.                                                                                                                                                                                                                                                   |
|      |              | 1     | Clears the respective overflow bit in the ADCINTOVF register. If software tries to set this bit on the same clock cycle that hardware tries to set the overflow bit in the ADCINTOVF register, then hardware has priority and the ADCINTOVF bit will be set. |

#### Table 6-8. ADC Interrupt Overflow Clear Register (ADCINTOVFCLR) Field Descriptions

NOTE: The following Interrupt Select Registers are EALLOW protected.

#### Figure 6-14. Interrupt Select 1 And 2 Register (INTSEL1N2) (Address Offset 08h)

| 15            | 14            | 13         | 12 |         | 8 |
|---------------|---------------|------------|----|---------|---|
| Reserved      | INT2CONT      | INT2E      |    | INT2SEL |   |
| R-0           | R/W-0         | R/W-0      |    | R/W-0   |   |
|               |               |            |    |         |   |
| 7             | 6             | 5          | 4  |         | 0 |
| 7<br>Reserved | 6<br>INT1CONT | 5<br>INT1E | 4  | INT1SEL | 0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Figure 6-15. Interrupt Select 3 And 4 Register (INTSEL3N4) (Address Offset 09h)

| 15            | 14            | 13         | 12 |         | 8 |
|---------------|---------------|------------|----|---------|---|
| Reserved      | INT4CONT      | INT4E      |    | INT4SEL |   |
| R-0           | R/W-0         | R/W-0      |    | R/W-0   |   |
|               |               |            |    |         |   |
| 7             | 6             | 5          | 4  |         | 0 |
| 7<br>Reserved | 6<br>INT3CONT | 5<br>INT3E | 4  | INT3SEL | 0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Figure 6-16. Interrupt Select 5 And 6 Register (INTSEL5N6) (Address Offset 0Ah)

| 15            | 14            | 13         | 12 |         | 8 |
|---------------|---------------|------------|----|---------|---|
| Reserved      | INT6CONT      | INT6E      |    | INT6SEL |   |
| R-0           | R/W-0         | R/W-0      |    | R/W-0   |   |
|               |               |            |    |         |   |
| 7             | 6             | 5          | 4  |         | 0 |
| 7<br>Reserved | 6<br>INT5CONT | 5<br>INT5E | 4  | INT5SEL | 0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Figure 6-17. Interrupt Select 7 And 8 Register (INTSEL7N8) (Address Offset 0Bh)

| 15       | 14       | 13    | 12 |         | 8 |
|----------|----------|-------|----|---------|---|
| Reserved | INT8CONT | INT8E |    | INT8SEL |   |
| R-0      | R/W-0    | R/W-0 |    | R/W-0   |   |
| 7        | 6        | 5     | 4  |         | 0 |
|          |          |       |    |         |   |
| Reserved | INT7CONT | INT7E |    | INT7SEL |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



#### Analog-to-Digital Converter (ADC)

www.ti.com

| Figure 6-18. Interrupt Select 9 And 10 Register (INTSEL9N10) (Address Offset 0Ch | ) |
|----------------------------------------------------------------------------------|---|
|----------------------------------------------------------------------------------|---|

| 15       |          |       |          |         | 8 |
|----------|----------|-------|----------|---------|---|
|          |          |       | Reserved |         |   |
|          |          |       | R-0      |         |   |
| 7        | 6        | 5     | 4        |         | 0 |
| Reserved | INT9CONT | INT9E |          | INT9SEL |   |
| R-0      | R/W-0    | R/W-0 |          | R/W-0   |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bit  | Field    | Value | Description                                                                                                     |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------|
| 15   | Reserved |       | Reserved                                                                                                        |
| 14   | INTyCONT |       | ADCINTy Continuous Mode Enable                                                                                  |
|      |          | 0     | No further ADCINTy pulses are generated until ADCINTy flag (in ADCINTFLG register) is cleared by user.          |
|      |          | 1     | ADCINTy pulses are generated whenever an EOC pulse is generated irrespective if the flag bit is cleared or not. |
| 13   | INTyE    |       | ADCINTy Interrupt Enable                                                                                        |
|      |          | 0     | ADCINTy is disabled.                                                                                            |
|      |          | 1     | ADCINTy is enabled.                                                                                             |
| 12-8 | INTySEL  |       | ADCINTy EOC Source Select                                                                                       |
|      |          | 00h   | EOC0 is trigger for ADCINTy                                                                                     |
|      |          | 01h   | EOC1 is trigger for ADCINTy                                                                                     |
|      |          | 02h   | EOC2 is trigger for ADCINTy                                                                                     |
|      |          | 03h   | EOC3 is trigger for ADCINTy                                                                                     |
|      |          | 04h   | EOC4 is trigger for ADCINTy                                                                                     |
|      |          | 05h   | EOC5 is trigger for ADCINTy                                                                                     |
|      |          | 06h   | EOC6 is trigger for ADCINTy                                                                                     |
|      |          | 07h   | EOC7 is trigger for ADCINTy                                                                                     |
|      |          | 08h   | EOC8 is trigger for ADCINTy                                                                                     |
|      |          | 09h   | EOC9 is trigger for ADCINTy                                                                                     |
|      |          | 0Ah   | EOC10 is trigger for ADCINTy                                                                                    |
|      |          | 0Bh   | EOC11 is trigger for ADCINTy                                                                                    |
|      |          | 0Ch   | EOC12 is trigger for ADCINTy                                                                                    |
|      |          | 0Dh   | EOC13 is trigger for ADCINTy                                                                                    |
|      |          | 0Eh   | EOC14 is trigger for ADCINTy                                                                                    |
|      |          | 0Fh   | EOC15 is trigger for ADCINTy                                                                                    |
|      |          | 1xh   | Invalid value.                                                                                                  |
| 7    | Reserved |       | Reserved                                                                                                        |
| 6    | INTxCONT |       | ADCINTx Continuous Mode Enable.                                                                                 |
|      |          | 0     | No further ADCINTx pulses are generated until ADCINTx flag (in ADCINTFLG register) is cleared by user.          |
|      |          | 1     | ADCINTx pulses are generated whenever an EOC pulse is generated irrespective if the flag bit is cleared or not. |
| 5    | INTxE    |       | ADCINTx Interrupt Enable                                                                                        |
|      |          | 0     | ADCINTx is disabled.                                                                                            |
|      |          | 1     | ADCINTx is enabled .                                                                                            |

# Table 6-9. INTSELxNy Register Field Descriptions

| Bit | Field   | Value | Description                  |
|-----|---------|-------|------------------------------|
| 4-0 | INTxSEL |       | ADCINTx EOC Source Select    |
|     |         | 00h   | EOC0 is trigger for ADCINTx  |
|     |         | 01h   | EOC1 is trigger for ADCINTx  |
|     |         | 02h   | EOC2 is trigger for IADCNTx  |
|     |         | 03h   | EOC3 is trigger for ADCINTx  |
|     |         | 04h   | EOC4 is trigger for ADCINTx  |
|     |         | 05h   | EOC5 is trigger for ADCINTx  |
|     |         | 06h   | EOC6 is trigger for ADCINTx  |
|     |         | 07h   | EOC7 is trigger for ADCINTx  |
|     |         | 08h   | EOC8 is trigger for ADCINTx  |
|     |         | 09h   | EOC9 is trigger for ADCINTx  |
|     |         | 0Ah   | EOC10 is trigger for ADCINTx |
|     |         | 0Bh   | EOC11 is trigger for ADCINTx |
|     |         | 0Ch   | EOC12 is trigger for ADCINTx |
|     |         | .0Dh  | EOC13 is trigger for ADCINTx |
|     |         | 0Eh   | EOC14 is trigger for ADCINTx |
|     |         | 0Fh   | EOC15 is trigger for ADCINTx |
|     |         | 1xh   | Invalid value.               |

# Table 6-9. INTSELxNy Register Field Descriptions (continued)

# 6.1.10.4 ADC Priority Register

NOTE: The following SOC Priority Control Register is EALLOW protected.

|          | Figure 6-19. A | DC Star | rt of Conversion Priority Control R | Registe | r (SOCPRICTL) |   |
|----------|----------------|---------|-------------------------------------|---------|---------------|---|
| 15       | 11             | 10      | 5                                   | 4       |               | 0 |
| Reserved |                |         | RRPOINTER                           |         | SOCPRIORITY   |   |
| R-0      |                |         | R-20h                               | R/W-0   |               |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Analog-to-Digital Converter (ADC)

www.ti.com

Texas Instruments

# Table 6-10. SOCPRICTL Register Field Descriptions

| Bit   | Field       | Value  | Description                                                                                                                                                                                                                                                                                                                                   |
|-------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-11 | Reserved    |        | Reserved                                                                                                                                                                                                                                                                                                                                      |
| 10-5  | RRPOINTER   |        | Round Robin Pointer. Holds the value of the last converted round robin SOCx to be used by the round robin scheme to determine order of conversions.                                                                                                                                                                                           |
|       |             | 00h    | SOC0 was last round robin SOC to convert. SOC1 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 01h    | SOC1 was last round robin SOC to convert. SOC2 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 02h    | SOC2 was last round robin SOC to convert. SOC3 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 03h    | SOC3 was last round robin SOC to convert. SOC4 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 04h    | SOC4 was last round robin SOC to convert. SOC5 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 05h    | SOC5 was last round robin SOC to convert. SOC6 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 06h    | SOC6 was last round robin SOC to convert. SOC7 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 07h    | SOC7 was last round robin SOC to convert. SOC8 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 08h    | SOC8 was last round robin SOC to convert. SOC9 is highest round robin priority.                                                                                                                                                                                                                                                               |
|       |             | 09h    | SOC9 was last round robin SOC to convert. SOC10 is highest round robin priority.                                                                                                                                                                                                                                                              |
|       |             | 0Ah    | SOC10 was last round robin SOC to convert. SOC11 is highest round robin priority.                                                                                                                                                                                                                                                             |
|       |             | 0Bh    | SOC11 was last round robin SOC to convert. SOC12 is highest round robin priority.                                                                                                                                                                                                                                                             |
|       |             | 0Ch    | SOC12 was last round robin SOC to convert. SOC13 is highest round robin priority.                                                                                                                                                                                                                                                             |
|       |             | 0Dh    | SOC13 was last round robin SOC to convert. SOC14 is highest round robin priority.                                                                                                                                                                                                                                                             |
|       |             | 0Eh    | SOC14 was last round robin SOC to convert. SOC15 is highest round robin priority.                                                                                                                                                                                                                                                             |
|       |             | 0Fh    | SOC15 was last round robin SOC to convert. SOC0 is highest round robin priority.                                                                                                                                                                                                                                                              |
|       |             | 1xh    | Invalid value                                                                                                                                                                                                                                                                                                                                 |
|       |             | 20h    | Reset value to indicate no SOC has been converted. SOC0 is highest round robin priority. Set to this value when the device is reset, when the ADCCTL1.RESET bit is set, or when the SOCPRICTL register is written. In the latter case, if a conversion is currently in progress, it will complete and then the new priority will take effect. |
|       |             | Others | Invalid selection.                                                                                                                                                                                                                                                                                                                            |
| 4-0   | SOCPRIORITY |        | SOC Priority.                                                                                                                                                                                                                                                                                                                                 |
|       |             |        | Determines the cutoff point for priority mode and round robin arbitration for SOCx                                                                                                                                                                                                                                                            |
|       |             | 00h    | SOC priority is handled in round robin mode for all channels.                                                                                                                                                                                                                                                                                 |
|       |             | 01h    | SOC0 is high priority, rest of channels are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 02h    | SOC0-SOC1 are high priority, SOC2-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 03h    | SOC0-SOC2 are high priority, SOC3-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 04h    | SOC0-SOC3 are high priority, SOC4-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 05h    | SOC0-SOC4 are high priority, SOC5-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 06h    | SOC0-SOC5 are high priority, SOC6-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 07h    | SOC0-SOC6 are high priority, SOC7-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 08h    | SOC0-SOC7 are high priority, SOC8-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 09h    | SOC0-SOC8 are high priority, SOC9-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                              |
|       |             | 0Ah    | SOC0-SOC9 are high priority, SOC10-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                             |
|       |             | 0Bh    | SOC0-SOC10 are high priority, SOC11-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                            |
|       |             | 0Ch    | SOC0-SOC11 are high priority, SOC12-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                            |
|       |             | 0Dh    | SOC0-SOC12 are high priority, SOC13-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                            |
|       |             | 0Eh    | SOC0-SOC13 are high priority, SOC14-SOC15 are in round robin mode.                                                                                                                                                                                                                                                                            |
|       |             | 0Fh    | SOC0-SOC14 are high priority, SOC15 is in round robin mode.                                                                                                                                                                                                                                                                                   |
|       | 1           | 10h    | All SOCs are in high priority mode, arbitrated by SOC number                                                                                                                                                                                                                                                                                  |
|       |             | 1011   | Air Socs are in high phoney mode, arbitrated by Soc humber                                                                                                                                                                                                                                                                                    |



# 6.1.10.5 ADC SOC Registers

**NOTE:** The following ADC Sample Mode Register is EALLOW protected.

# Figure 6-20. ADC Sample Mode Register (ADCSAMPLEMODE) (Address Offset 12h)

| 15        |           |           |          |          |          |          | 8        |  |  |  |
|-----------|-----------|-----------|----------|----------|----------|----------|----------|--|--|--|
|           |           |           | Rese     | erved    |          |          |          |  |  |  |
| R-0       |           |           |          |          |          |          |          |  |  |  |
| 7         | 6         | 5         | 4        | 3        | 2        | 1        | 0        |  |  |  |
| SIMULEN14 | SIMULEN12 | SIMULEN10 | SIMULEN8 | SIMULEN6 | SIMULEN4 | SIMULEN2 | SIMULEN0 |  |  |  |
| R/W-0     | R/W-0     | R/W-0     | R/W-0    | R/W-0    | R/W-0    | R/W-0    | R/W-0    |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 6-11. ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions

| Bit  | Field       | Value | Description                                                                                                                                                                                                                                                                     |
|------|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | Reserved    |       | Reserved                                                                                                                                                                                                                                                                        |
| 7    | 7 SIMULEN14 |       | Simultaneous sampling enable for SOC14/SOC15. Couples SOC14 and SOC15 in simultaneous sampling mode. See section 1.5 for details. This bit should not be set when the ADC is actively converting SOC14 or SOC15.                                                                |
|      |             | 0     | Single sample mode set for SOC14 and SOC15. All bits of CHSEL field define channel to be converted. EOC14 associated with SOC14. EOC15 associated with SOC15. SOC14's result placed in ADCRESULT14 register. SOC15's result placed in ADCRESULT15.                              |
|      |             | 1     | Simultaneous sample for SOC14 and SOC15. Lowest three bits of CHSEL field define the pair of channels to be converted. EOC14 and EOC15 associated with SOC14 and SOC15 pair. SOC14's and SOC15's results will be placed in ADCRESULT14 and ADCRESULT15 registers, respectively. |
| 6    | 6 SIMULEN12 |       | Simultaneous sampling enable for SOC12/SOC13. Couples SOC12 and SOC13 in simultaneous sampling mode. See section 1.5 for details. This bit should not be set when the ADC is actively converting SOC12 or SOC13.                                                                |
|      |             | 0     | Single sample mode set for SOC12 and SOC13. All bits of CHSEL field define channel to be converted. EOC12 associated with SOC12. EOC13 associated with SOC13. SOC12's result placed in ADCRESULT12 register. SOC13's result placed in ADCRESULT13.                              |
|      |             | 1     | Simultaneous sample for SOC12 and SOC13. Lowest three bits of CHSEL field define the pair of channels to be converted. EOC12 and EOC13 associated with SOC12 and SOC13 pair. SOC12's and SOC13's results will be placed in ADCRESULT12 and ADCRESULT13 registers, respectively. |
| 5    | SIMULEN10   |       | Simultaneous sampling enable for SOC10/SOC11. Couples SOC10 and SOC11 in simultaneous sampling mode. See section 1.5 for details. This bit should not be set when the ADC is actively converting SOC10 or SOC11.                                                                |
|      |             | 0     | Single sample mode set for SOC10 and SOC11. All bits of CHSEL field define channel to be converted. EOC10 associated with SOC10. EOC11 associated with SOC11. SOC10's result placed in ADCRESULT10 register. SOC11's result placed in ADCRESULT11.                              |
|      |             | 1     | Simultaneous sample for SOC10 and SOC11. Lowest three bits of CHSEL field define the pair of channels to be converted. EOC10 and EOC11 associated with SOC10 and SOC11 pair. SOC10's and SOC11's results will be placed in ADCRESULT10 and ADCRESULT11 registers, respectively. |
| 4    | SIMULEN8    |       | Simultaneous sampling enable for SOC8/SOC9. Couples SOC8 and SOC9 in simultaneous sampling mode. See section 1.5 for details. This bit should not be set when the ADC is actively converting SOC8 or SOC9.                                                                      |
|      |             | 0     | Single sample mode set for SOC8 and SOC9. All bits of CHSEL field define channel to be converted. EOC8 associated with SOC8. EOC9 associated with SOC9. SOC8's result placed in ADCRESULT8 register. SOC9's result placed in ADCRESULT9.                                        |
|      |             | 1     | Simultaneous sample for SOC8 and SOC9. Lowest three bits of CHSEL field define the pair of channels to be converted. EOC8 and EOC9 associated with SOC8 and SOC9 pair. SOC8's and SOC9's results will be placed in ADCRESULT8 and ADCRESULT9 registers, respectively.           |

#### Table 6-11. ADC Sample Mode Register (ADCSAMPLEMODE) Field Descriptions (continued)

| Bit | Field    | Value | Description                                                                                                                                                                                                                                                           |
|-----|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | SIMULEN6 |       | Simultaneous sampling enable for SOC6/SOC7. Couples SOC6 and SOC7 in simultaneous sampling mode. See section 1.5 for details. This bit should not be set when the ADC is actively converting SOC6 or SOC7.                                                            |
|     |          | 0     | Single sample mode set for SOC6 and SOC7. All bits of CHSEL field define channel to be converted. EOC6 associated with SOC6. EOC7 associated with SOC7. SOC6's result placed in ADCRESULT6 register. SOC7's result placed in ADCRESULT7.                              |
|     |          | 1     | Simultaneous sample for SOC6 and SOC7. Lowest three bits of CHSEL field define the pair of channels to be converted. EOC6 and EOC7 associated with SOC6 and SOC7 pair. SOC6's and SOC7's results will be placed in ADCRESULT6 and ADCRESULT7 registers, respectively. |
| 2   | SIMULEN4 |       | Simultaneous sampling enable for SOC4/SOC5. Couples SOC4 and SOC5 in simultaneous sampling mode. See section 1.5 for details. This bit should not be set when the ADC is actively converting SOC4 or SOC5.                                                            |
|     |          | 0     | Single sample mode set for SOC4 and SOC5. All bits of CHSEL field define channel to be converted. EOC4 associated with SOC4. EOC5 associated with SOC5. SOC4's result placed in ADCRESULT4 register. SOC5's result placed in ADCRESULT5.                              |
|     |          | 1     | Simultaneous sample for SOC4 and SOC5. Lowest three bits of CHSEL field define the pair of channels to be converted. EOC4 and EOC5 associated with SOC4 and SOC5 pair. SOC4's and SOC5's results will be placed in ADCRESULT4 and ADCRESULT5 registers, respectively. |
| 1   | SIMULEN2 |       | Simultaneous sampling enable for SOC2/SOC3. Couples SOC2 and SOC3 in simultaneous sampling mode. See section 1.5 for details. This bit should not be set when the ADC is actively converting SOC2 or SOC3.                                                            |
|     |          | 0     | Single sample mode set for SOC2 and SOC3. All bits of CHSEL field define channel to be converted. EOC2 associated with SOC2. EOC3 associated with SOC3. SOC2's result placed in ADCRESULT2 register. SOC3's result placed in ADCRESULT3.                              |
|     |          | 1     | Simultaneous sample for SOC2 and SOC3. Lowest three bits of CHSEL field define the pair of channels to be converted. EOC2 and EOC3 associated with SOC2 and SOC3 pair. SOC2's and SOC3's results will be placed in ADCRESULT2 and ADCRESULT3 registers, respectively. |
| 0   | SIMULEN0 |       | Simultaneous sampling enable for SOC0/SOC1. Couples SOC0 and SOC1 in simultaneous sampling mode. See section 1.5 for details. This bit should not be set when the ADC is actively converting SOC0 or SOC1.                                                            |
|     |          | 0     | Single sample mode set for SOC0 and SOC1. All bits of CHSEL field define channel to be converted. EOC0 associated with SOC0. EOC1 associated with SOC1. SOC0's result placed in ADCRESULT0 register. SOC1's result placed in ADCRESULT1.                              |
|     |          | 1     | Simultaneous sample for SOC0 and SOC1. Lowest three bits of CHSEL field define the pair of channels to be converted. EOC0 and EOC1 associated with SOC0 and SOC1 pair. SOC0's and SOC1's results will be placed in ADCRESULT0 and ADCRESULT1 registers, respectively. |

**NOTE:** The following ADC Interrupt SOC Select Registers are EALLOW protected.

# Figure 6-21. ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) (Address Offset 14h)

|       | 3 12  | 11 10 | 9 0   | 7 0   | 5 4   | 3 2   | 1 0   |
|-------|-------|-------|-------|-------|-------|-------|-------|
| SOC7  | SOC6  | SOC5  | SOC4  | SOC3  | SOC2  | SOC1  | SOC0  |
| R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 6-12. ADC Interrupt Trigger SOC Select 1 Register (ADCINTSOCSEL1) Register Field Descriptions

| Bit | Field                | Value | Description                                                                                                                                        |
|-----|----------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 150 | SOCx<br>(x = 7 to 0) |       | SOCx ADC Interrupt Trigger Select. Selects which, if any, ADCINT triggers SOCx. This field overrides the TRIGSEL field in the ADCSOCxCTL register. |
|     |                      | 00    | No ADCINT will trigger SOCx. TRIGSEL field determines SOCx trigger.                                                                                |
|     |                      | 01    | ADCINT1 will trigger SOCx. TRIGSEL field is ignored.                                                                                               |
|     |                      | 10    | ADCINT2 will trigger SOCx. TRIGSEL field is ignored.                                                                                               |
|     |                      | 11    | Invalid selection.                                                                                                                                 |

| Analog-to-Digital Converter (ADC) |
|-----------------------------------|
|-----------------------------------|

| Figure 6-22 |     | e 6-22. / | ADC In | terrup | t Trigge   | er SOC | Select | t 2 Reg | ister (/ |       | rsocs | EL2) (A | ddres | s Offse | et 15h) |
|-------------|-----|-----------|--------|--------|------------|--------|--------|---------|----------|-------|-------|---------|-------|---------|---------|
| 15          | 14  | 13        | 12     | 11     | 10         | 9      | 8      | 7       | 6        | 5     | 4     | 3       | 2     | 1       | 0       |
| SOC         | C15 | SO        | C14    | SO     | C13        | SO     | C12    | SO      | C11      | SO    | C10   | SO      | C9    | SC      | 0C8     |
| R/W-0       |     | R/W-0     |        | R/\    | /W-0 R/W-0 |        | V-0    | R/W-0   |          | R/W-0 |       | R/W-0   |       | RΛ      | V-0     |
|             |     |           |        |        |            |        |        |         |          |       |       |         |       |         |         |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 6-13. ADC Interrupt Trigger SOC Select 2 Register (ADCINTSOCSEL2) Field Descriptions

| Bit  | Field                 | Value | Description                                                                                                                                        |
|------|-----------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | SOCx<br>(x = 15 to 8) |       | SOCx ADC Interrupt Trigger Select. Selects which, if any, ADCINT triggers SOCx. This field overrides the TRIGSEL field in the ADCSOCxCTL register. |
|      |                       | 00    | No ADCINT will trigger SOCx. TRIGSEL field determines SOCx trigger.                                                                                |
|      |                       | 01    | ADCINT1 will trigger SOCx. TRIGSEL field is ignored.                                                                                               |
|      |                       | 10    | ADCINT2 will trigger SOCx. TRIGSEL field is ignored.                                                                                               |
|      |                       | 11    | Invalid selection.                                                                                                                                 |

# Figure 6-23. ADC SOC Flag 1 Register (ADCSOCFLG1) (Address Offset 18h)

|   | 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    |  |
|---|-------|-------|-------|-------|-------|-------|------|------|--|
| ſ | SOC15 | SOC14 | SOC13 | SOC12 | SOC11 | SOC10 | SOC9 | SOC8 |  |
| - | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0  | R-0  |  |
|   | 7     | 6     | 5     | 4     | 3     | 2     | 1    | 0    |  |
| ſ | SOC7  | SOC6  | SOC5  | SOC4  | SOC3  | SOC2  | SOC1 | SOC0 |  |
|   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0  | R-0  |  |
|   | K-0   | R-0   | K-0   | K-0   | K-0   | K-0   | K-0  | K-0  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 6-14. ADC SOC Flag 1 Register (ADCSOCFLG1) Field Descriptions

| Bit  | Field         | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|---------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | SOCx          |       | SOCx Start of Conversion Flag. Indicates the state of individual SOC conversions.                                                                                                                                                                                                                                                                                                                                                                    |
|      | (x = 15 to 0) | 0     | No sample pending for SOCx.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      |               | 1     | Trigger has been received and sample is pending for SOCx.                                                                                                                                                                                                                                                                                                                                                                                            |
|      |               |       | The bit will be automatically cleared when the respective SOCx conversion is started. If contention exists where this bit receives both a request to set <b>and</b> a request to clear on the same cycle, regardless of the source of either, this bit will be set and the request to clear will be ignored. In this case the overflow bit in the ADCSOCOVF1 register will not be affected regardless of whether this bit was previously set or not. |

# Figure 6-24. ADC SOC Force 1 Register (ADCSOCFRC1) (Address Offset 1Ah)

| 15        | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| SOC15     | SOC14     | SOC13     | SOC12     | SOC11     | SOC10     | SOC9      | SOC8      |
| R/W-0     |
|           |           |           |           |           |           |           |           |
| 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| 7<br>SOC7 | 6<br>SOC6 | 5<br>SOC5 | 4<br>SOC4 | 3<br>SOC3 | 2<br>SOC2 | 1<br>SOC1 | 0<br>SOC0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



Analog-to-Digital Converter (ADC)

www.ti.com

# Table 6-15. ADC SOC Force 1 Register (ADCSOCFRC1) Field Descriptions

| Bit  | Field                 | Value | Description                                                                                                                                                                                                                                                                                                                                      |
|------|-----------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | SOCx<br>(x = 15 to 0) |       | SOCx Force Start of Conversion Flag. Writing a 1 will force to 1 the respective SOCx flag bit in the ADCSOCFLG1 register. This can be used to initiate a software initiated conversion. Writes of 0 are ignored.                                                                                                                                 |
|      |                       | 0     | No action.                                                                                                                                                                                                                                                                                                                                       |
|      |                       | 1     | Force SOCx flag bit to 1. This will cause a conversion to start once priority is given to SOCx.                                                                                                                                                                                                                                                  |
|      |                       |       | If software tries to set this bit on the same clock cycle that hardware tries to clear the SOCx bit in the ADCSOCFLG1 register, then software has priority and the ADCSOCFLG1 bit will be set. In this case the overflow bit in the ADCSOCOVF1 register will not be affected regardless of whether the ADCSOCFLG1 bit was previously set or not. |

# Figure 6-25. ADC SOC Overflow 1 Register (ADCSOCOVF1) (Address Offset 1Ch)

| 15        | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| SOC15     | SOC14     | SOC13     | SOC12     | SOC11     | SOC10     | SOC9      | SOC8      |
| R-0       |
|           |           |           |           |           |           |           |           |
| 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| 7<br>SOC7 | 6<br>SOC6 | 5<br>SOC5 | 4<br>SOC4 | 3<br>SOC3 | 2<br>SOC2 | 1<br>SOC1 | 0<br>SOC0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 6-16. ADC SOC Overflow 1 Register (ADCSOCOVF1) Field Descriptions

| Bit  | Field                 | Value | Description                                                                                                                     |
|------|-----------------------|-------|---------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | SOCx<br>(x = 15 to 0) |       | SOCx Start of Conversion Overflow Flag. Indicates an SOCx event was generated while an existing SOCx event was already pending. |
|      |                       | 0     | No SOCx event overflow                                                                                                          |
|      |                       | 1     | SOCx event overflow                                                                                                             |
|      |                       |       | An overflow condition does not stop SOCx events from being processed. It simply is an indication that a trigger was missed      |

#### Figure 6-26. ADC SOC Overflow Clear 1 Register (ADCSOCOVFCLR1) (Address Offset 1Eh)

| 15        | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| SOC15     | SOC14     | SOC13     | SOC12     | SOC11     | SOC10     | SOC9      | SOC8      |
| W1C-0     |
|           |           |           |           |           |           |           |           |
| 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| 7<br>SOC7 | 6<br>SOC6 | 5<br>SOC5 | 4<br>SOC4 | 3<br>SOC3 | 2<br>SOC2 | 1<br>SOC1 | 0<br>SOC0 |

LEGEND: W1C = Write 1 to clear bit, reads return 0; -n = value after reset

# Table 6-17. ADC SOC Overflow Clear 1 Register (ADCSOCOVFCLR1) Field Descriptions

| Bit  | Field                 | Value | Description                                                                                                                                                                                      |
|------|-----------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | SOCx<br>(x = 15 to 0) |       | SOCx Clear Start of Conversion Overflow Flag. Writing a 1 will clear the respective SOCx overflow flag in the ADCSOCOVF1 register. Writes of 0 are ignored. Reads return 0.                      |
|      |                       | 0     | No action.                                                                                                                                                                                       |
|      |                       | 1     | Clear SOCx overflow flag.                                                                                                                                                                        |
|      |                       |       | If software tries to set this bit on the same clock cycle that hardware tries to set the overflow bit in the ADCSOCOVF1 register, then hardware has priority and the ADCSOCOVF1 bit will be set. |

**NOTE:** The following ADC SOC0 - SOC15 Control Registers are EALLOW protected.



Analog-to-Digital Converter (ADC)

|    | Figure 6-27. Al | oc soc | 0 - SOC15 C | ontrol | Registers (ADCSO | CxCTL) | (Address Offset 20h - 2F | h) |
|----|-----------------|--------|-------------|--------|------------------|--------|--------------------------|----|
| 15 |                 | 11     | 10          | 9      | 6                | 5      |                          | 0  |
|    | TRIGSEL         |        | Reserved    |        | CHSEL            |        | ACQPS                    |    |
|    | R/W-0           |        | R-0         |        | R/W-0            |        | R/W-0                    |    |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 6-18. ADC SOC0 - SOC15 Control Registers (ADCSOCxCTL) Register Field Descriptions

| Bit   | Field    | Value  | Description                                                                                                                                                                                                                                                        |
|-------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-11 | TRIGSEL  |        | SOCx Trigger Source Select.                                                                                                                                                                                                                                        |
|       |          |        | Configures which trigger will set the respective SOCx flag in the ADCSOCFLG1 register to intiate a conversion to start once priority is given to SOCx. This setting can be overridden by the respective SOCx field in the ADCINTSOCSEL1 or ADCINTSOCSEL2 register. |
|       |          | 00h    | ADCTRIG0 - Software only.                                                                                                                                                                                                                                          |
|       |          | 01h    | ADCTRIG1 - CPU Timer 0, TINT0n                                                                                                                                                                                                                                     |
|       |          | 02h    | ADCTRIG2 - CPU Timer 1, TINT1n                                                                                                                                                                                                                                     |
|       |          | 03h    | ADCTRIG3 - CPU Timer 2, TINT2n                                                                                                                                                                                                                                     |
|       |          | 04h    | ADCTRIG4 – XINT2, XINT2SOC                                                                                                                                                                                                                                         |
|       |          | 05h    | ADCTRIG5 – ePWM1, ADCSOCA                                                                                                                                                                                                                                          |
|       |          | 06h    | ADCTRIG6 – ePWM1, ADCSOCB                                                                                                                                                                                                                                          |
|       |          | 07h    | ADCTRIG7 – ePWM2, ADCSOCA                                                                                                                                                                                                                                          |
|       |          | 08h    | ADCTRIG8 – ePWM2, ADCSOCB                                                                                                                                                                                                                                          |
|       |          | 09h    | ADCTRIG9 – ePWM3, ADCSOCA                                                                                                                                                                                                                                          |
|       |          | 0Ah    | ADCTRIG10 – ePWM3, ADCSOCB                                                                                                                                                                                                                                         |
|       |          | 0Bh    | ADCTRIG11 – ePWM4, ADCSOCA                                                                                                                                                                                                                                         |
|       |          | 0Ch    | ADCTRIG12 – ePWM4, ADCSOCB                                                                                                                                                                                                                                         |
|       |          | 0Dh    | ADCTRIG13 – ePWM5, ADCSOCA                                                                                                                                                                                                                                         |
|       |          | 0Eh    | ADCTRIG14 – ePWM5, ADCSOCB                                                                                                                                                                                                                                         |
|       |          | 0Fh    | ADCTRIG15 – ePWM6, ADCSOCA                                                                                                                                                                                                                                         |
|       |          | 10h    | ADCTRIG16 – ePWM6, ADCSOCB                                                                                                                                                                                                                                         |
|       |          | 11h    | ADCTRIG17 - ePWM7, ADCSOCA                                                                                                                                                                                                                                         |
|       |          | 12h    | ADCTRIG18 - ePWM7, ADCSOCB                                                                                                                                                                                                                                         |
|       |          | Others | Invalid selection.                                                                                                                                                                                                                                                 |
| 10    | Reserved |        | Reserved                                                                                                                                                                                                                                                           |



| Bit | Field | Value | Description                                                                                          |
|-----|-------|-------|------------------------------------------------------------------------------------------------------|
| 9-6 | CHSEL |       | SOCx Channel Select. Selects the channel to be converted when SOCx is received by the ADC.           |
|     |       |       | Sequential Sampling Mode (SIMULENx = 0):                                                             |
|     |       | 0h    | ADCINA0                                                                                              |
|     |       | 1h    | ADCINA1                                                                                              |
|     |       | 2h    | ADCINA2                                                                                              |
|     |       | 3h    | ADCINA3                                                                                              |
|     |       | 4h    | ADCINA4                                                                                              |
|     |       | 5h    | ADCINA5                                                                                              |
|     |       | 6h    | ADCINA6                                                                                              |
|     |       | 7h    | ADCINA7                                                                                              |
|     |       | 8h    | ADCINB0                                                                                              |
|     |       | 9h    | ADCINB1                                                                                              |
|     |       | Ah    | ADCINB2                                                                                              |
|     |       | Bh    | ADCINB3                                                                                              |
|     |       | Ch    | ADCINB4                                                                                              |
|     |       | Dh    | ADCINB5                                                                                              |
|     |       | Eh    | ADCINB6                                                                                              |
|     |       | Fh    | ADCINB7                                                                                              |
|     |       |       | Simultaneous Sampling Mode (SIMULENx = 1):                                                           |
|     |       | 0h    | ADCINA0/ADCINB0 pair                                                                                 |
|     |       | 1h    | ADCINA1/ADCINB1 pair                                                                                 |
|     |       | 2h    | ADCINA2/ADCINB2 pair                                                                                 |
|     |       | 3h    | ADCINA3/ADCINB3 pair                                                                                 |
|     |       | 4h    | ADCINA4/ADCINB4 pair                                                                                 |
|     |       | 5h    | ADCINA5/ADCINB5 pair                                                                                 |
|     |       | 6h    | ADCINA6/ADCINB6 pair                                                                                 |
|     |       | 7h    | ADCINA7/ADCINB7 pair                                                                                 |
|     |       | 8h    | Invalid selection.                                                                                   |
|     |       | 9h    | Invalid selection.                                                                                   |
|     |       | Ah    | Invalid selection.                                                                                   |
|     |       | Bh    | Invalid selection.                                                                                   |
|     |       | Ch    | Invalid selection.                                                                                   |
|     |       | Dh    | Invalid selection.                                                                                   |
|     |       | Eh    | Invalid selection.                                                                                   |
|     |       | Fh    | Invalid selection.                                                                                   |
| 5-0 | ACQPS |       | SOCx Acquisition Prescale. Controls the sample and hold window for SOCx. Minimum value allowed is 6. |
|     |       |       | Sample window is (ACQPS +1) clock cycles.                                                            |

# Table 6-18. ADC SOC0 - SOC15 Control Registers (ADCSOCxCTL) Register Field Descriptions (continued)

# 6.1.10.6 ADC Calibration Registers

| NOTE: | The ADC Calibration Register is EALLOW protected. |
|-------|---------------------------------------------------|
|-------|---------------------------------------------------|

# TEXAS INSTRUMENTS

| www.ti.com Analog-to-D |        |                    |                   |        |        |                 | igital Converter | (ADC)        |   |
|------------------------|--------|--------------------|-------------------|--------|--------|-----------------|------------------|--------------|---|
|                        | Figure | <del>e</del> 6-28. | ADC Reference/Gai | n Trim | Regist | er (ADCREFTRIM) | (Address         | Offset 40h)  |   |
| 15                     | 14     | 13                 |                   | 9      | 8      | 5               | 4                |              | 0 |
| Reser                  | ved    |                    | EXTREF_FINE_TRIM  |        | B      | G_COARSE_TRIM   | E                | BG_FINE_TRIM |   |
| R-0                    |        |                    | R/W-0             |        |        | R/W-0           |                  | R/W-0        |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 6-19. ADC Reference/Gain Trim Register (ADCREFTRIM) Field Descriptions

| Bit   | Field            | Value | Description                                                                                                                                                              |
|-------|------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14 | Reserved         |       | Reserved                                                                                                                                                                 |
| 13-9  | EXTREF_FINE_TRIM |       | ADC External reference Fine Trim. These bits should not be modified after device boot code loads them with the factory trim setting.                                     |
| 8-5   | BG_COARSE_TRIM   |       | ADC Internal Bandgap Fine Trim. These bits should not be modified after device boot code loads them with the factory trim setting.                                       |
| 4-0   | BG_FINE_TRIM     |       | ADC Internal Bandgap Coarse Trim. A maximum value of 30 is supported. These bits should not be modified after device boot code loads them with the factory trim setting. |

# Figure 6-29. ADC Offset Trim Register (ADCOFFTRIM) (Address Offset 41h)

| 15 9     | 8 0     |
|----------|---------|
| Reserved | OFFTRIM |
| R-0      | R/W-0   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 6-20. ADC Offset Trim Register (ADCOFFTRIM) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                                                                        |
|------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-9 | Reserved |       | Reserved                                                                                                                                                                                                                           |
| 8-0  | OFFTRIM  |       | ADC Offset Trim. 2's complement of ADC offset. Range is -256 to +255. These bits are loaded by device boot code with a factory trim setting. Modification of this default setting can be made to correct any board induced offset. |

# 6.1.10.7 ADC Revision Register

# Figure 6-30. ADC Revision Register (ADCREV) (Address Offset 4Fh)

| 15 |      | 8 |
|----|------|---|
|    | REV  |   |
|    | R-x  |   |
| 7  |      | 0 |
|    | TYPE |   |
|    | R-3h |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 6-21. ADC Revision Register (ADCREV) Field Descriptions

| Bit  | Field | Value | Description                                                                                             |
|------|-------|-------|---------------------------------------------------------------------------------------------------------|
| 15-8 | REV   |       | ADC Revision. To allow documentation of differences between revisions. First version is labeled as 00h. |
| 7-0  | TYPE  | 3     | ADC Type. Always set to 3 for this type ADC                                                             |

# 6.1.10.8 ADC Result Registers

The ADC Result Registers are found in Peripheral Frame 0 (PF0). In the header files, the ADCRESULTx registers are located in the AdcResult register file, not AdcRegs.



#### Analog-to-Digital Converter (ADC)

Figure 6-31. ADC RESULT0 - RESULT15 Registers (ADCRESULTx) (PF1 Block Address Offset 00h - 0Fh)

|    |          |    |    | ,      |   |
|----|----------|----|----|--------|---|
| 15 |          | 12 | 11 |        | 0 |
|    | Reserved |    |    | RESULT |   |
|    | R-0      |    |    | R-0    |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 6-22. ADC RESULT0 - ADCRESULT15 Registers (ADCRESULTx) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Reserved |       | Reserved                                                                                                                                                                                                                                                                                                                                     |
| 11-0  | RESULT   |       | 12-bit right-justified ADC result                                                                                                                                                                                                                                                                                                            |
|       |          |       | Sequential Sampling Mode (SIMULENx = 0):                                                                                                                                                                                                                                                                                                     |
|       |          |       | After the ADC completes a conversion of an SOCx, the digital result is placed in the corresponding ADCRESULTx register. For example, if SOC4 is configured to sample ADCINA1, the completed result of that conversion will be placed in ADCRESULT4.                                                                                          |
|       |          |       | Simultaneous Sampling Mode (SIMULENx = 1):                                                                                                                                                                                                                                                                                                   |
|       |          |       | After the ADC completes a conversion of a channel pair, the digital results are found in the corresponding ADCRESULTx and ADCRESULTx+1 registers (assuming x is even). For example, for SOC4, the completed results of those conversions will be placed in ADCRESULT4 and ADCRESULT5. See 1.11 for timings of when this register is written. |

## 6.1.11 ADC Timings









Figure 6-33. Timing Example For Sequential Mode / Early Interrupt Pulse





Figure 6-34. Timing Example For Simultaneous Mode / Late Interrupt Pulse







Analog-to-Digital Converter and Comparator

**NOTE:** The NONOVERLAP bit in the ADCCTL2 register, when enabled, removes the overlap of sampling and conversion stages. This will eliminate 1st sample issue and improve INL/DNL performance.

#### 6.1.12 Internal Temperature Sensor

The internal temperature sensor measures the junction temperature of the device. The sensor output can be sampled with the ADC on channel A5 using a switch controlled by the ADCCTL1.TEMPCONV bit. The switch allows A5 to be used both as an external ADC input pin and the temperature sensor access point. When sampling the temperature sensor, the external circuitry on ADCINA5 has no affect on the sample. Refer to Section 6.1.10.1 for information about switching between the external ADCINA5 input pin and the internal temperature sensor.

#### 6.1.12.1 Transfer Function

The temperature sensor output and the resulting ADC values increase with increasing junction temperature. The offset is defined as the 0 °C LSB crossing as illustrated in Figure 6-37. This information can be used to convert the ADC sensor sample into a temperature unit.

The transfer function to determine a temperature is defined as:

Temperature = (sensor - Offset) \* Slope





Refer to the electrical characteristics section in ) *F2805x Microcontroller Data Manual* (SPRS797) for the slope and offset, or use the stored slope and offset calibrated per device in the factory which can be extract by a function at the following locations.

The values listed are assuming a 3.3v full scale range. Using the internal reference mode automatically achieves this fixed range, but if using the external mode, the temperature sensor values must be adjusted accordingly to the external reference voltages.

#### Example

The header files include an example project to easily sample the temperature sensor and convert the result into two different temperature units. There are three steps to using the temperature sensor:

1. Configure the ADC to sample the temperature sensor

#### Analog-to-Digital Converter (ADC)

#### www.ti.com

2. Sample the temperature sensor

3. Convert the result into a temperature unit, such as °C.

#### Here is an example of these steps:

```
// Configure the ADC to sample the temperature sensor
EALLOW;
AdcRegs.ADCCTL1.bit.TEMPCONV = 1;
                                     //Connect A5 - temp sensor
AdcRegs.ADCSOC0CTL.bit.CHSEL = 5;
                                     //Set SOC0 to sample A5
AdcRegs.ADCSOC1CTL.bit.CHSEL = 5;
                                     //Set SOC1 to sample A5
AdcRegs.ADCSOC0CTL.bit.ACQPS = 6; //Set SOC0 ACQPS to 7 ADCCLK
AdcRegs.ADCSOC1CTL.bit.ACQPS = 6; //Set SOC1 ACQPS to 7 ADCCLK
AdcRegs.INTSEL1N2.bit.INT1SEL = 1; //Connect ADCINT1 to EOC1
AdcRegs.INTSEL1N2.bit.INT1E = 1;
                                    //Enable ADCINT1
EDIS;
// Sample the temperature sensor
AdcRegs.ADCSOCFRC1.all = 0x03;
                                           //Sample temp sensor
while(AdcRegs.ADCINTFLG.bit.ADCINT1 == 0){} //Wait for ADCINT1
AdcRegs.ADCINTFLGCLR.bit.ADCINT1 = 1;
                                          //Clear ADCINT1
sensorSample = AdcResult.ADCRESULT1;
                                           //Get temp sensor sample result
```

//Convert raw temperature sensor output to a temperature (i.e. degC)
DegreesC = (sensorSample - TempSensorOffset) \* TempSensorSlope;



Page

# Analog Front-End (AFE) Modules

The Analog Front-End (AFE) is composed of a number of modules which are useful for level-shifting, amplifying, and monitoring analog input signals. These modules include programmable gain amplifiers (PGAs), analog comparators, internal reference digital-to-analog converters (DACs), and a buffered VREFOUT DAC.

#### Topic

| Programmable Gain Amplifier (PGA)                       | 477                                                                                                                                                                                                                                                         |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Buffered Voltage Reference DAC (VREFOUT)                | 477                                                                                                                                                                                                                                                         |
| Voltage Comparator and DAC Reference                    | 478                                                                                                                                                                                                                                                         |
| PGA-Only Example                                        | 479                                                                                                                                                                                                                                                         |
| Bipolar Examples                                        | 479                                                                                                                                                                                                                                                         |
| Digital Filter                                          | 480                                                                                                                                                                                                                                                         |
| Comparator and Digital Filter Subsystem                 | 481                                                                                                                                                                                                                                                         |
| Analog Front-End and ADC Integration                    | 484                                                                                                                                                                                                                                                         |
| Analog Front-End and Digital Filter Subsystem Registers | 485                                                                                                                                                                                                                                                         |
|                                                         | Buffered Voltage Reference DAC (VREFOUT)         Voltage Comparator and DAC Reference         PGA-Only Example         Bipolar Examples         Digital Filter         Comparator and Digital Filter Subsystem         Analog Front-End and ADC Integration |



## 7.1 Programmable Gain Amplifier (PGA)

The programmable gain amplifier (PGA) is used to amplify the input signal that feeds into the downstream comparator and ADC channel as shown in Figure 7-1.



Note that while the PGA op-amp can be disabled through the PGAEN register, the PGA cannot be bypassed to achieve an unamplified signal path to the comparator and ADC channel.

The active component in the PGA is an internal op-amp that is configured as a non-inverting amplifier with internal feedback resistors. These internal feedback resistors are paired to produce voltage gains of x3, x6, or x11. The gain selection is software programmable through the AMPxx\_GAIN registers, but one or more of these registers may be locked on some devices. See the device data manual to determine if the PGA gain is software-selectable or if the gain is locked to a fixed selection.

The high (positive) voltage supply for the op-amp is sourced from analog power (VDDA), and the low (negative) voltage supply is sourced from the respective module's analog ground (M1GND, M2GND, or PFCGND).

The PGA output may exhibit non-linear behavior near the supply rails (VDDA/GND). See the device datasheet to determine the valid operating range of the PGA.

A conceptual model of the PGA is shown in Figure 7-2.



Figure 7-2. PGA Model

The PGA gain can be calculated by using the resistor ratios alone. For example, the x3 gain is derived from:

$$Gain = 1 + \frac{2z}{1z}$$

Note that only the resistor ratios are considered when calculating the PGA gain.

Write-access to PGA-related configuration registers may be locked through the LOCKAMPCOMP register. Only a system reset can restore write-access. Some devices may be preconfigured to program the lock registers at boot.

# 7.2 Buffered Voltage Reference DAC (VREFOUT)

A buffered 6-bit DAC (VREFOUT) is used to generate a programmable reference voltage. In combination with external resistors, a DC offset and resistor-divider gain can be introduced to the input signals.

The 6-bit DAC and its output buffer are both supplied by the VREFHI and VSSA analog supplies.

The VREFOUT buffer output may exhibit non-linear behavior near the supply rails (VREFHI/VSSA). See the device datasheet to determine the valid operating range of the buffered DAC.



A pull-down resistor is connected to the output of VREFOUT and it cannot be disconnected. This is true even when the buffered DAC is disabled. In configurations where VREFOUT is multiplexed with an ADC channel, the pull-down resistor will reduce the ADC input impedance on that channel.

A conceptual model of VREFOUT is shown in Figure 7-3.

#### Figure 7-3. VREFOUT Model



The ideal output of the DAC can be calculated as follows:

$$VREFOUT = \frac{(VREFOUTCTL_DACVAL + 1) \times VREFHI}{64}$$

Write-access to VREFOUT-related configuration registers may be locked through the LOCKDAC register. Only a system reset can restore write-access. Some devices may be preconfigured to program the lock registers at boot.

## 7.3 Voltage Comparator and DAC Reference

The voltage comparator is an analog component that monitors two input voltages and generates a digital output which indicates whether the voltage on the positive input is greater than the negative input.

#### Figure 7-4. Voltage Comparator



Table 7-1. Comparator Truth Table

| Voltages              | Output |
|-----------------------|--------|
| Voltage A > Voltage B | 1      |
| Voltage B > Voltage A | 0      |

Within the AFE, the comparator positive signal is driven by a PGA, and the negative signal is driven by an internal 6-bit DAC reference voltage.

The 6-bit DAC is supplied by the VDDA and VSSA analog supplies, and its ideal output can be calculated as follows:

$$DACx Output = \frac{(DACxCTL_DACVAL + 1) \times VDDA}{64}$$

The comparator block diagram is shown in Figure 7-5.

#### Figure 7-5. Comparator Block Diagram



Write-access to comparator-related configuration registers may be locked through the LOCKAMPCOMP register. Write-access to DAC-related configuration registers may be locked through the LOCKDAC register. Only a system reset can restore write-access. Some devices may be preconfigured to program the lock registers at boot.

#### 7.4 PGA-Only Example

Given a small positive signal, the PGA can be used to amplify the signal for higher resolution ADC sampling and trip monitoring. For example, an input signal with a valid range between 0.25V and 0.75V can be amplified in x3 mode to produce an output signal between 0.75V and 2.25V.



#### Figure 7-6. PGA-Only Example

#### 7.5 Bipolar Examples

With bipolar signals (having both positive and negative voltages), the VREFOUT buffered DAC can be used in combination with external resistors and PGA to offset the signal into a positive signal range for ADC sampling.

#### 7.5.1 Signal Amplification and Offset

Suppose that the input signal has a valid range between -0.5V and +0.5V, and signal amplification is desired. In the configuration below, the internal post-PGA output signal will range between 0.65V and 2.65V.



Figure 7-7. Signal Amplification

The voltage at the PGA input can be calculated as follows:

Digital Filter

www.ti.com

$$VPGA = \frac{2z \times (VSIG - VREF)}{1z + 2z} + VREF$$

Note that only the resistor ratios are considered in the equation above.

# 7.6 Digital Filter

Digital filters are included at the comparator outputs to qualify the comparator output signals using a majority filter scheme.

## 7.6.1 Filter Behavior

The digital filter works on a window of FIFO samples (SAMPWIN + 1) taken from the input. The filter output resolves to the majority value of the sample window, where majority is defined by the threshold (THRESH) value. If the majority threshold is not satisfied, the filter output remains unchanged.

For proper operation, the value of THRESH must be greater than SAMPWIN / 2.

A prescale function (CLKPRESCALE) determines the filter sampling rate, where the filter FIFO captures one sample every CLKPRESCALE system clocks. Old data from the FIFO is discarded.

A conceptual model of the digital filter is shown in Figure 7-8.





```
if (FILTER_OUTPUT == 0) {
    if ( Num_ls_in_SAMPWIN >=THRESH ) {
        FILTER_OUTPUT = 1;
    }
}
else {
    if ( Num_0s_in_SAMPWIN >= THRESH ) {
        FILTER_OUTPUT = 0;
    }
}
```

Write-access to digital-filter-related configuration registers may be locked through the LOCKCTRIP register. Only a system reset can restore write-access. Some devices may be preconfigured to program the lock registers at boot.

# 7.6.2 Filter Initialization

TEXAS

www.ti.com

**ISTRUMENTS** 

To ensure proper operation of the digital filter, the following initialization sequence is recommended:

- 1. Configure and enable comparators for operation in CTRIPxxICTL
- 2. Configure the digital filter parameters for operation
  - Set CTRIPxxFILCTL\_SAMPWIN for the number of samples to monitor in FIFO window
  - Set CTRIPxxFILCTL\_THRESH for the threshold required for majority qualification
  - Set the digital filter clock prescale value in CTRIPxxFILCLKCTL to the desired value
- 3. Initialize the sample values in the digital filter FIFO window by setting CTRIPxxFILCTL\_FILINIT
- 4. Configure the CTRIP and CTRIPOUT signal paths in CTRIPxxOCTL
- 5. If desired, configure the EPWM and GPIO modules to accept the filtered signals

# 7.7 Comparator and Digital Filter Subsystem

For this family of devices, the comparator and digital filter components are grouped by subsystems: Motor 1 (M1), Motor 2 (M2), and Power Factor Correction (PFC). Each device offering will only include a partial set of the subsystems. See the device data manual to determine which subsystems are available.

A common output subsystem determines how the comparator trip signals are distributed to the digital domain of the device.

The block diagram of the comparator and digital filter subsystem architecture is shown in Figure 7-9.



Figure 7-9. Comparator and DFSS Block Diagram



#### Comparator and Digital Filter Subsystem

#### 7.7.1 Comparator Subsystem

Each comparator subsystem monitors one PGA against at least one reference DAC. The comparator output can be disabled or inverted through the COMPxxICTL registers.

The block diagram for a motor comparator subsystem is shown in Figure 7-10, and a diagram of a PFC comparator subsystem is shown in Figure 7-11.



#### Figure 7-10. M1 Comparator Subsystem Block Diagram





Write-access to comparator-subsystem-related configuration registers may be locked through the LOCKAMPCOMP, LOCKDAC, and LOCKCTRIP registers. Only a system reset can restore write-access. Some devices may be preconfigured to program the lock registers at boot.

## 7.7.2 Digital Filter Subsystem (DFSS)

The digital filter subsystem (DFSS) qualifies the incoming comparator signals according to the CTRIPxxFILCTL register settings. If unqualified comparator signals are desired, the subsystem includes filter bypass paths which can be enabled through the CTRIPxxICTL register settings.

The block diagram for the digital filter subsystem is shown in Figure 7-12.





#### Figure 7-12. Digital Filter Subsystem Block Diagram

Write-access to digital-filter-subsystem-related configuration registers may be locked through the LOCKCTRIP register. Only a system reset can restore write-access. Some devices may be preconfigured to program the lock registers at boot.

# 7.7.3 Comparator Trip (CTRIP) Output Subsystem

The comparator trip (CTRIP) output subsystem combines the comparator trip signals by motor or PFC subsystems. Individual CTRIP signals are enabled or disabled through the CTRIPxxOCTL registers. The combined CTRIP and CTRIPOUT signals are then dispatched to downstream EPWM and GPIO modules.

Raw status and level flag status for each CTRIP signal are maintained in the CTRIPxxSTS registers. The CTRIP signals that are destined for EPWM are always represented as flags, but the CTRIPOUT path to GPIOs can be configured to bypass the latched flag if the raw signal is desired. Once set, the level flags can only be cleared through the corresponding bits in the CTRIPxxFLGCLR registers.

The block diagram of the subsystem CTRIP output subsystem is shown in Figure 7-13.



#### Figure 7-13. CTRIP Output Subsystem Block Diagram



Write-access to CTRIP-output-subsystem-related configuration registers may be locked through the LOCKCTRIP register. Only a system reset can restore write-access. Some devices may be preconfigured to program the lock registers at boot.

# 7.8 Analog Front-End and ADC Integration

Each PGA output is routed to both a comparator subsystem and one ADC channel. This provides the ability to both continuously monitor the PGA output for voltage trip events, and also to periodically sample the PGA output voltage with the ADC.

ADC input switches allow certain PGA outputs to be routed to multiple ADC channels. This feature is useful for implementing a faster sampling rate on a single PGA output by using multiple ADC channels for simultaneous conversions. The switches are configured through the ADCINSWITCH register.

A block diagram for the ADC connections is shown in Figure 7-14.



Figure 7-14. AFE and ADC Block Diagram

Write-access to the ADCINSWITCH register is locked through the LOCKSWITCH register. Only a system reset can restore write-access. Some devices may be preconfigured to program the lock registers at boot.



# 7.9 Analog Front-End and Digital Filter Subsystem Registers

# 7.9.1 DAC Control Registers

NOTE: The following registers are all EALLOW protected.

#### Table 7-2. DAC Control Registers

| Name       | Address Range | Size (x16) | Description         |
|------------|---------------|------------|---------------------|
| DAC1CTL    | 0x6400        | 1          | DAC1 Control        |
| DAC2CTL    | 0x6401        | 1          | DAC2 Control        |
| Reserved   | 0x6402        | 1          | Reserved            |
| Reserved   | 0x6403        | 1          | Reserved            |
| DAC5CTL    | 0x6404        | 1          | DAC5 Control        |
| VREFOUTCTL | 0x6405        | 1          | VREFOUT DAC Control |

## 7.9.1.1 DAC1-DAC5 Control Register (DACxCTL)

The DAC1-DAC5 Control Register (DACxCTL) is shown and described in the figure and table below.

These registers are EALLOW protected.

These registers can be locked through the LOCKDAC register.

#### Figure 7-15. DAC1-DAC5 Control Register (DACxCTL)

| 15       | 6 | 5 0    |  |
|----------|---|--------|--|
| Reserved |   | DACVAL |  |
| R-0      |   | R/W-0  |  |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 7-3. DAC1-DAC5 Control Register (DACxCTL) Field Descriptions

| Bit  | Field    | Value | Description |
|------|----------|-------|-------------|
| 15-6 | Reserved |       | Reserved    |
| 5-0  | DACVAL   | 0-3Fh | DAC Output  |



Analog Front-End and Digital Filter Subsystem Registers

## 7.9.1.2 VREF Output Control Register (VREFOUTCTL)

The VREF Output Control Register (VREFOUTCTL) is shown and described in the figure and table below.

These registers are EALLOW protected.

These registers can be locked through the LOCKDAC register.

#### Figure 7-16. VREF Output Control Register (VREFOUTCTL)

| 15 6     | 5 0    |
|----------|--------|
| Reserved | DACVAL |
| R-0      | R/W-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7-4. VREF Output Control Register (VREFOUTCTL) Field Descriptions

| Bit  | Field    | Value | Description          |
|------|----------|-------|----------------------|
| 15-6 | Reserved |       | Reserved             |
| 5-0  | DACVAL   | 0-3Fh | DAC VREFOUTAL Output |



## 7.9.2 DAC, PGA, Comparator, and Filter Enable Registers

The following registers are all EALLOW protected.

| Name         | Address Range | Size (x16) | Description                           |  |  |
|--------------|---------------|------------|---------------------------------------|--|--|
| DACEN        | 0x6410        | 1          | DAC Enable                            |  |  |
| VREFOUTEN    | 0x6411        | 1          | VREFOUT Enable                        |  |  |
| PGAEN        | 0x6412        | 1          | Programmable Gain Amplifier<br>Enable |  |  |
| COMPEN       | 0x6413        | 1          | Comparator Enable                     |  |  |
| AMPM1_GAIN   | 0x6414        | 1          | Motor Unit 1 PGA Gain<br>controls     |  |  |
| AMPM2_GAIN   | 0x6415        | 1          | Motor Unit 2 PGA Gain controls        |  |  |
| AMP_PFC_GAIN | 0x6416        | 1          | PFC PGA Gain controls                 |  |  |

#### Table 7-5. DAC, PGA, Comparator, and Filter Enable Registers

## 7.9.2.1 DAC Enable Register (DACEN)

The DAC Enable Register (DACEN) is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKDAC register.

#### Figure 7-17. DAC Enable Register (DACEN)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7-6. DAC Enable Register (DACEN) Field Descriptions

| Bit  | Field    | Value | Description                |
|------|----------|-------|----------------------------|
| 15-5 | Reserved |       | Reserved                   |
| 4    | DAC5EN   |       | DAC5 Enable                |
|      |          | 0     | DAC Disabled (Output=Hi-Z) |
|      |          | 1     | DAC Enabled                |
| 3-2  | Reserved |       | Reserved                   |
| 1    | DAC2EN   |       | DAC2 Enable                |
|      |          | 0     | DAC Disabled (Output=Hi-Z) |
|      |          | 1     | DAC Enabled.               |
| 0    | DAC1EN   |       | DAC1 Enable                |
|      |          | 0     | DAC Disabled (Output=Hi-Z) |
|      |          | 1     | DAC Enabled                |



# 7.9.2.2 VREF Out Enable Register (VREFOUTEN)

The VREF Out Enable Register (VREFOUTEN) is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKDAC register.

# Figure 7-18. VREF Out Enable Register (VREFOUTEN)

| 15       | 1 | 0            |
|----------|---|--------------|
| Reserved |   | DACVREFOUTEN |
| R-0      |   | R/W-0        |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 7-7. VREF Out Enable Register (VREFOUTEN) Field Descriptions

| Bit  | Field        | Value | Description                |
|------|--------------|-------|----------------------------|
| 15-1 | Reserved     |       | Reserved                   |
| 0    | DACVREFOUTEN |       | VREFOUT DAC Enable         |
|      |              | 0     | DAC Disabled (Output=Hi-Z) |
|      |              | 1     | DAC Enabled                |

www.ti.com

## 7.9.2.3 PGA Enable Register (PGAEN)

The PGA Enable (PGAEN) register is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKAMPCOMP register.

## Figure 7-19. PGA Enable Register (PGAEN)

| 15       |               |               |                  |         |         |                | 8       |
|----------|---------------|---------------|------------------|---------|---------|----------------|---------|
|          |               |               | Rese             | erved   |         |                |         |
|          |               |               | R                | -0      |         |                |         |
| 7        | 6             | 5             | 4                | 3       | 2       | 1              | 0       |
| Reserved | AMPB7EN       | AMPB6EN       | AMPB4EN          | AMPA6EN | AMPB1EN | <b>AMPA3EN</b> | AMPA1EN |
| R-0      | R/W-0         | R/W-0         | R/W-0            | R/W-0   | R/W-0   | R/W-0          | R/W-0   |
|          | Deed/Mitter D | Deed only n y | alua aftar raaat |         |         |                |         |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7-8. PGA Enable Register (PGAEN) Field Descriptions

| Bit  | Field          | Value | Description          |
|------|----------------|-------|----------------------|
| 15-7 | Reserved       |       | Reserved             |
| 6    | AMPB7EN        |       | Amp Enable on ADC B7 |
|      |                | 0     | Disable Amp          |
|      |                | 1     | Enable Amp           |
| 5    | AMPB6EN        |       | Amp Enable on ADC B6 |
|      |                | 0     | Disable Amp          |
|      |                | 1     | Enable Amp           |
| 4    | AMPB4EN        |       | Amp Enable on ADC B4 |
|      |                | 0     | Disable Amp          |
|      |                | 1     | Enable Amp           |
| 3    | AMPA6EN        |       | Amp Enable on ADC A6 |
|      |                | 0     | Disable Amp          |
|      |                | 1     | Enable Amp           |
| 2    | AMPB1EN        |       | Amp Enable on ADC B1 |
|      |                | 0     | Disable Amp          |
|      |                | 1     | Enable Amp           |
| 1    | <b>AMPA3EN</b> |       | Amp Enable on ADC A3 |
|      |                | 0     | Disable Amp          |
|      |                | 1     | Enable Amp           |
| 0    | AMPA1EN        |       | Amp Enable on ADC A1 |
|      |                | 0     | Disable Amp          |
|      |                | 1     | Enable Amp           |



#### 7.9.2.4 Comparator Enable Register (COMPEN)

The Comparator Enable (COMPEN) register is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKAMPCOMP register.

#### Figure 7-20. Comparator Enable Register (COMPEN)

| 15       |                  |                  |                  |          |          |          | 8        |
|----------|------------------|------------------|------------------|----------|----------|----------|----------|
|          |                  |                  | Rese             | erved    |          |          |          |
|          |                  |                  | R                | -0       |          |          |          |
| 7        | 6                | 5                | 4                | 3        | 2        | 1        | 0        |
| Reserved | COMPB1EN         | Reserved         | COMPA3EN         | Reserved | COMPA1EN | Reserved | COMPB7EN |
| R-0      | R/W-0            | R-0              | R/W-0            | R-0      | R/W-0    | R-0      | R/W-0    |
|          | - Rood/Mitor R - | Road only: n - y | alua oftar roaat |          |          |          |          |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 7-9. Comparator Enable Register (COMPEN) Field Descriptions

| Bit  | Field    | Value | Description                      |
|------|----------|-------|----------------------------------|
| 15-7 | Reserved |       | Reserved                         |
| 6    | COMPB1EN |       | Comparator COMPB1H,L Enable      |
|      |          | 0     | Disable Comparator (output is 0) |
|      |          | 1     | Enable Comparator                |
| 5    | Reserved |       | Reserved                         |
| 4    | COMPA3EN |       | Comparator COMPA3H,L Enable      |
|      |          | 0     | Disable Comparator (output is 0) |
|      |          | 1     | Enable Comparator                |
| 3    | Reserved |       | Reserved                         |
| 2    | COMPA1EN |       | Comparator COMPA1H,L Enable      |
|      |          | 0     | Disable Comparator (output is 0) |
|      |          | 1     | Enable Comparator                |
| 1    | Reserved |       | Reserved                         |
| 0    | COMPB7EN |       | Comparator COMPB7 Enable         |
|      |          | 0     | Disable Comparator (output is 0) |
|      |          | 1     | Enable Comparator                |

## 7.9.2.5 M1 Amplifier Gain Control Register (AMPM1\_GAIN)

The M1 Amplifier Gain Control (AMPM1\_GAIN) register is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKAMPCOMP register.

#### Figure 7-21. M1 Amplifier Gain Control Register (AMPM1\_GAIN)

| 15   |       |      |       |     | 10    | 9    | 8     |
|------|-------|------|-------|-----|-------|------|-------|
|      |       | Res  | erved |     |       | AMPB | 1GAIN |
|      |       | R    | 2-0   |     |       | R/V  | V-0   |
| 7    | 6     | 5    | 4     | 3   | 2     | 1    | 0     |
| Rese | erved | AMPA | 3GAIN | Res | erved | AMPA | 1GAIN |
| R    | -0    | RA   | W-0   | R   | -0    | R/V  | V-0   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 7-10. M1 Amplifier Gain Control Register (AMPM1\_GAIN) Field Descriptions

| Bit   | Field     | Value | Description                    |  |  |  |
|-------|-----------|-------|--------------------------------|--|--|--|
| 15-10 | Reserved  |       | Reserved                       |  |  |  |
| 9-8   | AMPB1GAIN |       | MP B1 Internal Gain Selection  |  |  |  |
|       |           | 00    | Gain = 3                       |  |  |  |
|       |           | 01    | Gain = 6                       |  |  |  |
|       |           | 10    | Gain = 11                      |  |  |  |
|       |           | 11    | Reserved                       |  |  |  |
| 7-6   | Reserved  |       | Reserved                       |  |  |  |
| 5-4   | AMPA3GAIN |       | AMP A3 Internal Gain Selection |  |  |  |
|       |           | 00    | Gain = 3                       |  |  |  |
|       |           | 01    | Gain = 6                       |  |  |  |
|       |           | 10    | Gain = 11                      |  |  |  |
|       |           | 11    | Reserved                       |  |  |  |
| 3-2   | Reserved  |       | Reserved                       |  |  |  |
| 1-0   | AMPA1GAIN |       | AMP A1 Internal Gain Selection |  |  |  |
|       |           | 00    | Gain = 3                       |  |  |  |
|       |           | 01    | Gain = 6                       |  |  |  |
|       |           | 10    | Gain = 11                      |  |  |  |
|       |           | 11    | Reserved                       |  |  |  |



#### 7.9.2.6 M2 Amplifier Gain Control Register (AMPM2\_GAIN)

The M2 Amplifier Gain Control (AMPM2\_GAIN) register is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKAMPCOMP register.

#### Figure 7-22. M2 Amplifier Gain Control Register (AMPM2\_GAIN)

| 15       |   |      |            |     | 10         | 9    | 8     |
|----------|---|------|------------|-----|------------|------|-------|
| Reserved |   |      |            |     |            |      | 6GAIN |
| R-0      |   |      |            |     |            | R    | -0    |
| 7        | 6 | 5    | 4          | 3   | 2          | 1    | 0     |
| Reserved |   | AMPB | 34GAIN     | Res | erved      | AMPA | 6GAIN |
| R-0      |   | R    | <b>R-0</b> | R   | <b>!-0</b> | R    | -0    |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7-11. M2 Amplifier Gain Control Register (AMPM2\_GAIN) Field Descriptions

| Bit   | Field     | Value | Description                    |  |  |  |
|-------|-----------|-------|--------------------------------|--|--|--|
| 15-10 | Reserved  |       | Reserved                       |  |  |  |
| 9-8   | AMPB6GAIN |       | MP B6 Internal Gain Selection  |  |  |  |
|       |           | 00    | Gain = 3                       |  |  |  |
|       |           | 01    | Gain = 6                       |  |  |  |
|       |           | 10    | Gain = 11                      |  |  |  |
|       |           | 11    | Reserved                       |  |  |  |
| 7-6   | Reserved  |       | Reserved                       |  |  |  |
| 5-4   | AMPB4GAIN |       | AMP B4 Internal Gain Selection |  |  |  |
|       |           | 00    | Gain = 3                       |  |  |  |
|       |           | 01    | Gain = 6                       |  |  |  |
|       |           | 10    | Gain = 11                      |  |  |  |
|       |           | 11    | Reserved                       |  |  |  |
| 3-2   | Reserved  |       | Reserved                       |  |  |  |
| 1-0   | AMPA6GAIN |       | AMP A6 Internal Gain Selection |  |  |  |
|       |           | 00    | Gain = 3                       |  |  |  |
|       |           | 01    | Gain = 6                       |  |  |  |
|       |           | 10    | Gain = 11                      |  |  |  |
|       |           | 11    | Reserved                       |  |  |  |



#### Analog Front-End and Digital Filter Subsystem Registers

#### 7.9.2.7 PFC Amplifier Gain Control Register (AMP\_PFC\_GAIN)

The PFC Amplifier Gain Control Register (AMP\_PFC\_GAIN) is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKAMPCOMP register.

## Figure 7-23. PFC Amplifier Gain Control Register (AMP\_PFC\_GAIN)

| 15       | 2 | 1    | 0      |
|----------|---|------|--------|
| Reserved |   | AMPE | 37GAIN |
| R-0      |   | R/   | W-0    |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

## Table 7-12. PFC Amplifier Gain Control Register (AMP\_PFC\_GAIN) Field Descriptions

| Bit  | Field     | Value | Description                    |
|------|-----------|-------|--------------------------------|
| 15-2 | Reserved  |       | Reserved                       |
| 0    | AMPB7GAIN |       | AMP B7 Internal Gain Selection |
|      |           | 00    | Gain = 3                       |
|      |           | 01    | Gain = 6                       |
|      |           | 10    | Gain = 11                      |
|      |           | 11    | Reserved                       |



#### 7.9.3 Switch Registers

**NOTE:** The following registers are all EALLOW protected.

#### Table 7-13. Switch Registers

| Name        | Address Range | Size (x16) | Description                     |
|-------------|---------------|------------|---------------------------------|
| Reserved    | 0x6420        | 1          | Reserved                        |
| ADCINSWITCH | 0x6421        | 1          | ADC input-select switch control |
| Reserved    | 0x6422-0x6428 | 7          | Reserved                        |
| COMPHYSTCTL | 0x6429        | 1          | Comparator Hysteresis Control   |

#### 7.9.3.1 ADC Input Switch Control Register (ADCINSWITCH)

The ADC Input Switch Control Register (ADCINSWITCH) is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKSWITCH register.

#### Figure 7-24. ADC Input Switch Control Register (ADCINSWITCH)

| 15 |          |    |            |            |            | 8          |  |
|----|----------|----|------------|------------|------------|------------|--|
|    |          | Re | served     |            |            |            |  |
|    | R-0      |    |            |            |            |            |  |
| 7  |          | 4  | 3          | 2          | 1          | 0          |  |
|    | Reserved |    | ADCINB6SEL | ADCINA6SEL | ADCINB1SEL | ADCINA1SEL |  |
|    | R-0      |    | R/W-0      | R/W-0      | R/W-0      | R/W-0      |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7-14. ADC Input Switch Control Register (ADCINSWITCH) Field Descriptions

| Bit  | Field      | Value | Description                                     |  |
|------|------------|-------|-------------------------------------------------|--|
| 15-4 | Reserved   |       | Reserved                                        |  |
| 3    | ADCINB6SEL |       | ADC B6 input select                             |  |
|      |            | 0     | Amp B6 output is internally connected to ADC B6 |  |
|      |            | 1     | Amp B4 output is internally connected to ADC B6 |  |
| 2    | ADCINA6SEL |       | ADC A6 select                                   |  |
|      |            | 0     | Amp A6 output is internally connected to ADC A6 |  |
|      |            | 1     | Amp B4 output is internally connected to ADC A6 |  |
| 1    | ADCINB1SEL |       | ADC B1 input select                             |  |
|      |            | 0     | Amp B1 output is internally connected to ADC B1 |  |
|      |            | 1     | Amp A3 output is internally connected to ADC B1 |  |
| 0    | ADCINA1SEL |       | ADC A1 input select                             |  |
|      |            | 0     | Amp A1 output is internally connected to ADC A1 |  |
|      |            | 1     | Amp A3 output is internally connected to ADC A1 |  |



#### 7.9.3.2 Comparator Hysteresis Control Register (COMPHYSTCTL)

The Comparator Hysteresis Control Register (COMPHYSTCTL) is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKSWITCH register.

#### Figure 7-25. Comparator Hysteresis Control Register (COMPHYSTCTL)

|                         |                         |                              |                                           |                                                            |                                                                                                                                               | 8                                                                                                                                                                                                     |
|-------------------------|-------------------------|------------------------------|-------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         |                         | R                            | eserved                                   |                                                            |                                                                                                                                               |                                                                                                                                                                                                       |
|                         |                         |                              | R-0                                       |                                                            |                                                                                                                                               |                                                                                                                                                                                                       |
| 6                       | 5                       | 4                            | 3                                         | 2                                                          | 1                                                                                                                                             | 0                                                                                                                                                                                                     |
| COMPB7_HYST_<br>DISABLE | Rese                    | erved                        | COMPB1_HYST_<br>DISABLE                   | Reserved                                                   | COMPA3_HYST_<br>DISABLE                                                                                                                       | COMPA1_HYST<br>DISABLE                                                                                                                                                                                |
| R/W-0                   | R                       | -0                           | R/W-0                                     | R-0                                                        | R/W-0                                                                                                                                         | R/W-0                                                                                                                                                                                                 |
|                         | COMPB7_HYST_<br>DISABLE | COMPB7_HYST_ Rese<br>DISABLE | 6 5 4<br>COMPB7_HYST_ Reserved<br>DISABLE | 6543COMPB7_HYST_<br>DISABLEReservedCOMPB1_HYST_<br>DISABLE | 6         5         4         3         2           COMPB7_HYST_<br>DISABLE         Reserved         COMPB1_HYST_<br>DISABLE         Reserved | R-0           6         5         4         3         2         1           COMPB7_HYST_<br>DISABLE         Reserved         COMPB1_HYST_<br>DISABLE         Reserved         COMPA3_HYST_<br>DISABLE |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 7-15. Comparator Hysteresis Control Register (COMPHYSTCTL) Field Descriptions

| Bit  | Field        | Value | Description                      |  |
|------|--------------|-------|----------------------------------|--|
| 15-7 | Reserved     |       | Reserved                         |  |
| 6    | COMPB7_HYST_ |       | Disable B7 comparator hysteresis |  |
|      | DISABLE      | 0     | Enable hysteresis                |  |
|      |              | 1     | Disable hysteresis               |  |
| 5-4  | Reserved     |       | Reserved                         |  |
| 3    | COMPB1_HYST_ |       | Disable B1 comparator hysteresis |  |
|      | DISABLE 0    |       | Enable hysteresis                |  |
|      |              | 1     | Disable hysteresis               |  |
| 2    | Reserved     |       | Reserved                         |  |
| 1    | COMPA3_HYST_ |       | Disable A3 comparator hysteresis |  |
|      | DISABLE 0    |       | Enable hysteresis                |  |
|      |              | 1     | Disable hysteresis               |  |
| 0    | COMPA1_HYST_ |       | Disable A1 comparator hysteresis |  |
|      | DISABLE      | 0     | Enable hysteresis                |  |
|      |              | 1     | Disable hysteresis               |  |

#### 7.9.4 Digital Filter and Comparator Control Registers

NOTE: The following registers are all EALLOW protected.

| Name             | Address Range | Size (x16) | Description                                  |
|------------------|---------------|------------|----------------------------------------------|
| CTRIPA1ICTL      | 0x6430        | 1          | CTRIPA1 Filter Input &<br>Function Control   |
| CTRIPA1FILCTL    | 0x6431        | 1          | CTRIPA1 Filter parameters                    |
| CTRIPA1FILCLKCTL | 0x6432        | 1          | CTRIPA1 Filter Sample Clock<br>Control       |
| Reserved         | 0x6433        | 1          | Reserved                                     |
| CTRIPA3ICTL      | 0x6434        | 1          | CTRIPA3 Filter Input &<br>Function Control   |
| CTRIPA3FILCTL    | 0x6435        | 1          | CTRIPA3 Filter parameters                    |
| CTRIPA3FILCLKCTL | 0x6436        | 1          | CTRIPA3 Filter Sample Clock<br>Control       |
| Reserved         | 0x6437        | 1          | Reserved                                     |
| CTRIPB1ICTL      | 0x6438        | 1          | CTRIPB1 Filter Input &<br>Function Control   |
| CTRIPB1FILCTL    | 0x6439        | 1          | CTRIPB1 Filter parameters                    |
| CTRIPB1FILCLKCTL | 0x643A        | 1          | CTRIPB1 Filter Sample Clock<br>Control       |
| Reserved         | 0x643B        | 1          | Reserved                                     |
| Reserved         | 0x643C        | 1          | Reserved                                     |
| CTRIPM1OCTL      | 0x643D        | 1          | CTRIPM1 CTRIP Filter Output<br>Control       |
| CTRIPM1STS       | 0x643E        | 1          | CTRIPM1 CTRIPxx outputs status               |
| CTRIPM1FLGCLR    | 0x643F        | 1          | CTRIPM1 CTRIPxx flag clear                   |
| Reserved         | 0x6440-0x644F | 16         | Reserved                                     |
| Reserved         | 0x6450        | 1          | Reserved                                     |
| Reserved         | 0x6451        | 1          | Reserved                                     |
| Reserved         | 0x6452        | 1          | Reserved                                     |
| Reserved         | 0x6453        | 1          | Reserved                                     |
| Reserved         | 0x6454        | 1          | Reserved                                     |
| Reserved         | 0x6455        | 1          | Reserved                                     |
| Reserved         | 0x6456        | 1          | Reserved                                     |
| Reserved         | 0x6457        | 1          | Reserved                                     |
| Reserved         | 0x6458        | 1          | Reserved                                     |
| Reserved         | 0x6459        | 1          | Reserved                                     |
| Reserved         | 0x645A        | 1          | Reserved                                     |
| Reserved         | 0x645B        | 1          | Reserved                                     |
| Reserved         | 0x645C        | 1          | Reserved                                     |
| Reserved         | 0x645D        | 1          | Reserved                                     |
| Reserved         | 0x645E        | 1          | Reserved                                     |
| Reserved         | 0x645F        | 1          | Reserved                                     |
| Reserved         | 0x6460-0x646F | 16         | Reserved                                     |
| CTRIPB7ICTL      | 0x6470        | 1          | CTRIPB7 Filter Input and<br>Function Control |
| CTRIPB7FILCTL    | 0x6471        | 1          | CTRIPB7 Filter parameters                    |

#### Table 7-16. Digital Filter and Comparator Control Registers

| Name             | Address Range | Size (x16) | Description                            |
|------------------|---------------|------------|----------------------------------------|
| CTRIPB7FILCLKCTL | 0x6472        | 1          | CTRIPB7 Filter Sample Clock<br>Control |
| Reserved         | 0x6473-0x647B | 9          | Reserved                               |
| Reserved         | 0x647C        | 1          | Reserved                               |
| CTRIPPFCOCTL     | 0x647D        | 1          | CTRIPPFC CTRIPxx outputs status        |
| CTRIPPFCSTS      | 0x647E        | 1          | CTRIPPFC CTRIPxx flag clear            |
| CTRIPPFCFLGCLR   | 0x647F        | 1          | CTRIPPFC COMP Test<br>Control          |

#### Table 7-16. Digital Filter and Comparator Control Registers (continued)

# 7.9.4.1 CTRIP A1, A3, B1 Filter Input and Function Control Registers (CTRIPxxICTL)

The CTRIP A1, A3, B1 filter input and function control registers (CTRIPxxICTL) are shown and described in the figure and table below.

These registers are EALLOW protected.

These registers can be locked through the LOCKCTRIP register.

#### Figure 7-26. CTRIP A1, A3, B1 Filter Input and Function Control Registers (CTRIPxxICTL)

|    | •        |             |            | -          | •        | ,        |
|----|----------|-------------|------------|------------|----------|----------|
| 15 | 13       | 12          | 11         | 10         |          | 8        |
|    | Reserved | CTRIPOUTBYP | CTRIPBYP   |            | Reserved |          |
|    | R-0      | R/W-0       | R/W-0      |            | R-0      |          |
| 7  |          | 4           | 3          | 2          | 1        | 0        |
|    | Reserved |             | COMPLINPEN | COMPHINPEN | COMPLPOL | COMPHPOL |
|    | R-0      | R/W-0       | R/W-0      | R/W-0      | R/W-0    |          |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 7-17. CTRIP A1, A3, B1 Filter Input and Function Control Registers (CTRIPxxICTL) Field Descriptions

| Bit   | Field       | Value | Description                   |
|-------|-------------|-------|-------------------------------|
| 15-13 | Reserved    |       | Reserved                      |
| 12    | CTRIPOUTBYP |       | CTRIPOUT Filter bypass        |
|       |             | 0     | Filtered output of comparator |
|       |             | 1     | Bypass digital filter         |
| 11    | CTRIPBYP    |       | CTRIP Filter bypass           |
|       |             | 0     | Filtered output of comparator |
|       |             | 1     | Bypass digital filter         |
| 10-4  | Reserved    |       | Reserved                      |
| 3     | COMPLINPEN  |       | COMPL input enable            |
|       |             | 0     | COMPL disabled                |
|       |             | 1     | COMPL enabled                 |
| 2     | COMPHINPEN  |       | COMPH input enable            |
|       |             | 0     | COMPH disabled                |
|       |             | 1     | COMPH enabled                 |
| 1     | COMPLPOL    |       | COMPL Polarity control        |
|       |             | 0     | COMPL output is not inverted  |
|       |             | 1     | COMPL output is inverted      |



# Table 7-17. CTRIP A1, A3, B1 Filter Input and Function Control Registers (CTRIPxxICTL) Field Descriptions (continued)

| Bit | Field    | Value | Description                  |
|-----|----------|-------|------------------------------|
| 0   | COMPHPOL |       | COMPH Polarity control       |
|     |          | 0     | COMPH output is not inverted |
|     |          | 1     | COMPH output is inverted     |

#### 7.9.4.2 CTRIP B7 Filter Input and Function Control Register (CTRIPB7ICTL)

The TRIP B7 filter Input and function control register (CTRIPB7ICTL) is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKCTRIP register.

#### Figure 7-27. CTRIP B7 Filter Input and Function Control Register (CTRIPB7ICTL)

|    | -        |          | -           |          | -         | •        | •       |
|----|----------|----------|-------------|----------|-----------|----------|---------|
| 15 |          | 13       | 12          | 11       | 10        |          | 8       |
|    | Reserved |          | CTRIPOUTBYP | CTRIPBYP |           | Reserved |         |
|    | R-0      |          | R/W-0       | R/W-0    |           | R-0      |         |
| 7  |          |          |             | 3        | 2         | 1        | 0       |
|    |          | Reserved |             |          | COMPINPEN | Reserved | COMPPOL |
|    |          | R-0      |             |          | R/W-0     | R-0      | R/W-0   |
|    |          |          |             |          |           |          |         |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7-18. CTRIP B7 Filter Input and Function Control Register (CTRIPB7ICTL) Field Descriptions

| Bit   | Field       | Value | Description                   |
|-------|-------------|-------|-------------------------------|
| 15-13 | Reserved    |       | Reserved                      |
| 12    | CTRIPOUTBYP |       | CTRIPOUT Filter bypass        |
|       |             | 0     | Filtered output of comparator |
|       |             | 1     | Bypass digital filter         |
| 11    | CTRIPBYP    |       | CTRIP Filter bypass           |
|       |             | 0     | Filtered output of comparator |
|       |             | 1     | Bypass digital filter         |
| 10-3  | Reserved    |       | Reserved                      |
| 2     | COMPINPEN   |       | COMP input enable             |
|       |             | 0     | COMP disabled                 |
|       |             | 1     | COMP enabled                  |
| 1     | Reserved    |       | Reserved                      |
| 0     | COMPPOL     |       | COMP Polarity control         |
|       |             | 0     | COMP output is not inverted   |
|       |             | 1     | COMP output is inverted       |

#### 7.9.4.3 CTRIP A1, A3, B1, B7 Filter Parameter Control Registers (CTRIPxxFILCTL)

The CTRIP A1, A3, B1, B7 filter parameter control fegister (CTRIPxxFILCTL) is shown and described in the figure and table below.

These registers ares EALLOW protected.

These registers can be locked through the LOCKCTRIP register.

#### Figure 7-28. CTRIP A1, A3, B1, B7 Filter Parameter Control Registers (CTRIPxxFILCTL)

| 15      | 14       | 13  |   |        | 9        | 8       |
|---------|----------|-----|---|--------|----------|---------|
| FILINIT | Reserved |     |   | THRESH |          | SAMPWIN |
| R=0/W=1 | R-0      |     |   | R/W-0  |          | R/W-0   |
| 7       |          |     | 4 | 3      |          | 0       |
|         | SAMP     | WIN |   |        | Reserved |         |
|         | R/W-     | -0  |   |        | R-0      |         |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 7-19. CTRIP A1, A3, B1, B7 Filter Parameter Control Registers (CTRIPxxFILCTL) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                               |
|------|----------|-------|---------------------------------------------------------------------------------------------------------------------------|
| 15   | FILINIT  |       | CTRIP Filter Initialization. (Reads return 0)                                                                             |
|      |          | 0     | No effect                                                                                                                 |
|      |          | 1     | Initialize all samples to filter input value                                                                              |
| 14   | Reserved |       | Reserved                                                                                                                  |
| 13-9 | THRESH   |       | Majority voting threshold. At least THRESH samples must be of the opposite state in order for the output to change state. |
|      |          | 0-1Fh | THRESH must be greater than SAMPWIN / 2.                                                                                  |
| 8-4  | SAMPWIN  |       | Sample window size.                                                                                                       |
|      |          | 0-1Fh | Number of samples to monitor is SAMPWIN+1.                                                                                |
| 3-0  | Reserved |       | Reserved                                                                                                                  |

## 7.9.4.4 CTRIP A1, A3, B1, B7 Filter Sample Clock Control Registers (CTRIPxxFILCLKCTL)

The CTRIP A1, A3, B1, B7 filter sample clock control register (CTRIPxxFILCLKCTL) is shown and described in the figure and table below.

These registers are EALLOW protected.

These registers can be locked through the LOCKCTRIP register.

#### Figure 7-29. CTRIP A1, A3, B1, B7 Filter Sample Clock Control Registers (CTRIPxxFILCLKCTL)

| 15 8     | 7 0         |
|----------|-------------|
| Reserved | CLKPRESCALE |
| R/W-0    | R/W-0       |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 7-20. CTRIP A1, A3, B1, B7 Filter Parameter Control Registers (CTRIPxxFILCTL) Field Descriptions

| Bit  | Field       | Value | Description                                                           |
|------|-------------|-------|-----------------------------------------------------------------------|
| 15-8 | Reserved    |       | Reserved                                                              |
| 7-0  | CLKPRESCALE | 0-FFh | Sample clock prescale value. Number of system clocks between samples. |



#### 7.9.4.5 CTRIP M1 Filter Output Control Registers (CTRIPM1OCTL)

The CTRIP M1 filter output control register (CTRIPM1OCTL) is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKCTRIP register.

#### Figure 7-30. CTRIP M1 Filter Output Control Registers (CTRIPM10CTL)

|               | •           |          |          | •  | <b>U</b> (     | ,                   |                |
|---------------|-------------|----------|----------|----|----------------|---------------------|----------------|
| 15            | 14          | 13       |          | 11 | 10             | 9                   | 8              |
| CTRIPOUTLATEN | CTRIPOUTPOL |          | Reserved |    | CTRIPB1OUTEN   | <b>CTRIPA3OUTEN</b> | CTRIPA1OUTEN   |
| R/W-0         | R/W-0       |          | R-0      |    | R/W-0          | R/W-0               | R/W-0          |
|               |             |          |          |    |                |                     |                |
| 7             |             |          |          | 3  | 2              | 1                   | 0              |
| 7             |             | Reserved |          | 3  | 2<br>CTRIPB1EN | 1<br>CTRIPA3EN      | 0<br>CTRIPA1EN |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 7-21. CTRIP M1 Filter Output Control Registers (CTRIPM10CTL) Field Descriptions

| Bit   | Field               | Value | Description                                            |
|-------|---------------------|-------|--------------------------------------------------------|
| 15    | CTRIPOUTLATEN       |       | CTRIPOUTM1 synchronous latch enable                    |
|       |                     | 0     | CTRIPOUTM1 output is asynchronous                      |
|       |                     | 1     | CTRIPOUTM1 output is latched synchronously with SYSCLK |
| 14    | CTRIPOUTPOL         |       | CTRIPOUT Polarity                                      |
|       |                     | 0     | CTRIPM1OUT is not inverted                             |
|       |                     | 1     | CTRIPM1OUT is inverted                                 |
| 13-11 | Reserved            |       | Reserved                                               |
| 10    | CTRIPB1OUTEN        |       | CTRIPB1 enable for CTRIPOUTM1                          |
|       |                     | 0     | Disabled                                               |
|       |                     | 1     | Enabled                                                |
| 9     | <b>CTRIPA3OUTEN</b> |       | CTRIPA3 enable for CTRIPOUTM1                          |
|       |                     | 0     | Disabled                                               |
|       |                     | 1     | Enabled                                                |
| 8     | CTRIPA1OUTEN        |       | CTRIPA1 enable for CTRIPOUTM1                          |
|       |                     | 0     | Disabled                                               |
|       |                     | 1     | Enabled                                                |
| 7-3   | Reserved            |       | Reserved                                               |
| 2     | CTRIPB1EN           |       | CTRIPB1 enable for CTRIPM1                             |
|       |                     | 0     | Disabled                                               |
|       |                     | 1     | Enabled                                                |
| 1     | CTRIPA3EN           |       | CTRIPA3 enable for CTRIPM1                             |
|       |                     | 0     | Disabled                                               |
|       |                     | 1     | Enabled                                                |
| 0     | CTRIPA1EN           |       | CTRIPA1 enable for CTRIPM1                             |
|       |                     | 0     | Disabled                                               |
|       |                     | 1     | Enabled                                                |



## 7.9.4.6 CTRIP M1 Filter Output Status Registers (CTRIPM1STS)

The CTRIP M1 filter output status register (CTRIPM1STS) is shown and described in the figure and table below.

This register is EALLOW protected.

## Figure 7-31. CTRIP M1 Filter Output Status Registers (CTRIPM1STS)

| -             |    |          | •  | •          |                   |            |
|---------------|----|----------|----|------------|-------------------|------------|
| 15            | 14 |          | 11 | 10         | 9                 | 8          |
| CTRIPOUTM1FLG |    | Reserved |    | CTRIPB1FLG | CTRIPA3FLG        | CTRIPA1FLG |
| R-0           |    | R-0      |    | R-0        | R-0               | R-0        |
| 7             | 6  |          | 3  | 2          | 1                 | 0          |
| CTRIPOUTM1STS |    | Reserved |    | CTRIPB1STS | <b>CTRIPA3STS</b> | CTRIPA1STS |
|               |    | Reserveu |    | CIRIFDISIS | CTRIFA3313        | CIRIFAISIS |
| R-0           |    | R-0      |    | R-0        | R-0               | R-0        |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

## Table 7-22. CTRIP M1 Filter Output Status Registers (CTRIPM1STS) Field Descriptions

| Bit   | Field         | Value | Description                                                                                  |
|-------|---------------|-------|----------------------------------------------------------------------------------------------|
| 15    | CTRIPOUTM1FLG |       | CTRIPOUTM1 latched output level flag. Synchronous with SYSCLK. Cleared with CTRIPOUTM1FLGCLR |
|       |               | 0     | CTRIPOUTM1 event not detected                                                                |
|       |               | 1     | CTRIPOUTM1 event detected                                                                    |
| 14-11 | Reserved      |       | Reserved                                                                                     |
| 10    | CTRIPB1FLG    |       | CTRIPB1 latched output level flag. Synchronous with SYSCLK. Cleared with CTRIPB1FLGCLR.      |
|       |               | 0     | CTRIPB1 event not detected                                                                   |
|       |               | 1     | CTRIPB1 event detected                                                                       |
| 9     | CTRIPA3FLG    |       | CTRIPA3 latched output level flag. Synchronous with SYSCLK. Cleared with CTRIPA3FLGCLR.      |
|       |               | 0     | CTRIPA3 event not detected                                                                   |
|       |               | 1     | CTRIPA3 event detected                                                                       |
| 8     | CTRIPA1FLG    |       | CTRIPA1 latched output level flag. Synchronous with SYSCLK. Cleared with CTRIPA1FLGCLR.      |
|       |               | 0     | CTRIPA1 event not detected                                                                   |
|       |               | 1     | CTRIPA1 event detected                                                                       |
| 7     | CTRIPOUTM1STS |       | CTRIPOUTM1 output status at last SYSCLK edge                                                 |
|       |               | 0     | Event not detected                                                                           |
|       |               | 1     | Event detected                                                                               |
| 6-3   | Reserved      |       | Reserved                                                                                     |
| 2     | CTRIPB1STS    |       | CTRIPB1 output status at last SYSCLK edge                                                    |
|       |               | 0     | Event not detected                                                                           |
|       |               | 1     | Event detected                                                                               |
| 1     | CTRIPA3STS    |       | CTRIPA3 output status at last SYSCLK edge                                                    |
|       |               | 0     | Event not detected                                                                           |
|       |               | 1     | Event detected                                                                               |
| 0     | CTRIPA1STS    |       | CTRIPA1 output status at last SYSCLK edge                                                    |
|       |               | 0     | Event not detected                                                                           |
|       |               | 1     | Event detected                                                                               |



#### 7.9.4.7 CTRIP M1 Filter Output Flag Clear Register (CTRIPM1FLGCLR)

The CTRIP M1 filter output flag clear register (CTRIPM1FLGCLR) is shown and descried in the figure and table below.

This register is EALLOW protected.

#### Figure 7-32. CTRIP M1 Filter Output Flag Clear Registers (CTRIPM1FLGCLR)

|                  |    |          | ••••• |               |               | -,            |
|------------------|----|----------|-------|---------------|---------------|---------------|
| 15               | 14 |          | 11    | 10            | 9             | 8             |
| CTRIPOUTM1FLGCLR |    | Reserved |       | CTRIPB1FLGCLR | CTRIPA3FLGCLR | CTRIPA1FLGCLR |
| R/W1C            |    | R-0      |       | R/W1C         | R/W1C         | R/W1C         |
| 7                |    |          |       |               |               | 0             |
|                  |    | Reserved |       |               |               |               |
|                  |    | R-0      |       |               |               |               |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 7-23. CTRIP M1 Filter Output Flag Clear Registers (CTRIPM1FLGCLR) Field Descriptions

| Bit   | Field            | Value | Description                               |
|-------|------------------|-------|-------------------------------------------|
| 15    | CTRIPOUTM1FLGCLR |       | CTRIPOUTM1FLG flag clear. Reads return 0. |
|       |                  | 0     | No effect                                 |
|       |                  | 1     | Clear CTRIPOUTM1FLG                       |
| 14-11 | Reserved         |       | Reserved                                  |
| 10    | CTRIPB1FLGCLR    |       | CTRIPB1FLG flag clear. Reads return 0.    |
|       |                  | 0     | No effect                                 |
|       |                  | 1     | Clear CTRIPB1FLG                          |
| 9     | CTRIPA3FLGCLR    |       | CTRIPA3FLG flag clear. Reads return 0.    |
|       |                  | 0     | No effect                                 |
|       |                  | 1     | Clear CTRIPA3FLG                          |
| 8     | CTRIPA1FLGCLR    |       | CTRIPA1FLG flag clear. Reads return 0.    |
|       |                  | 0     | No effect                                 |
|       |                  | 1     | Clear CTRIPA1FLG                          |
| 7-0   | Reserved         |       | Reserved                                  |

## 7.9.4.8 CTRIP PFC Filter Output Control Register (CTRIPPFCOCTL)

The CTRIP PFC filter output control register (CTRIPPFCOCTL) is shown and described in the figure and table below.

This register is EALLOW protected.

This register can be locked through the LOCKCTRIP register.

#### Figure 7-33. CTRIP PFC Filter Output Control Register (CTRIPPFCOCTL)

|               |             | -    |      |       | •         |
|---------------|-------------|------|------|-------|-----------|
| 15            | 14          | 13   | 9    |       | 8         |
| CTRIPOUTLATEN | CTRIPOUTPOL | Rese | rved | CTRIF | PB7OUTEN  |
| R/W-0         | R/W-0       |      |      | F     | R/W-0     |
| 7             |             |      |      | 1     | 0         |
|               | Reserved    |      |      |       | CTRIPB7EN |
| R-0           |             |      |      |       |           |
|               |             |      |      |       |           |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7-24. CTRIP PFC Filter Output Control Register (CTRIPPFCOCTL) Field Descriptions

| Bit  | Field         | Value | Description                                             |
|------|---------------|-------|---------------------------------------------------------|
| 15   | CTRIPOUTLATEN |       | CTRIPOUTPFC synchronous latch enable                    |
|      |               | 0     | CTRIPOUTPFC output is asynchronous                      |
|      |               | 1     | CTRIPOUTPFC output is latched synchronously with SYSCLK |
| 14   | CTRIPOUTPOL   |       | CTRIPOUT Polarity CTRIPPF                               |
|      |               | 0     | COUT is not inverted                                    |
|      |               | 1     | CTRIPPFCOUT is inverted                                 |
| 13-9 | Reserved      |       | Reserved                                                |
| 8    | CTRIPB7OUTEN  |       | CTRIPB7 enable for CTRIPPFC                             |
|      |               | 0     | Disabled                                                |
|      |               | 1     | Enabled                                                 |
| 7-1  | Reserved      |       | Reserved                                                |
| 0    | CTRIPB7EN     |       | CTRIPB7 enable for CTRIPPFC                             |
|      |               | 0     | Disabled                                                |
|      |               | 1     | Enabled                                                 |



#### 7.9.4.9 CTRIP PFC Filter Output Status Register (CTRIPPFCSTS)

The CTRIP PFC filter output status register (CTRIPPFCSTS) is shown and described in the figure and table below.

This register is EALLOW protected.

#### Figure 7-34. CTRIP PFC Filter Output Status Register (CTRIPPFCSTS)

| -              |    |          | • • |            |
|----------------|----|----------|-----|------------|
| 15             | 14 |          | 9   | 8          |
| CTRIPOUTPFCFLG |    | Reserved |     | CTRIPB7FLG |
| R-0            |    | R-0      |     | R-0        |
| 7              | 6  |          | 1   | 0          |
| CTRIPOUTPFCSTS |    | Reserved |     | CTRIPB7STS |
|                |    | 10001100 |     |            |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7-25. CTRIP PFC Filter Output Status Register (CTRIPPFCSTS) Field Descriptions

| Bit  | Field          | Value | Description                                                                                     |
|------|----------------|-------|-------------------------------------------------------------------------------------------------|
| 15   | CTRIPOUTPFCFLG |       | CTRIPOUTPFC latched output level flag. Synchronous with SYSCLK. Cleared with CTRIPOUTPFCFLGCLR. |
|      |                | 0     | Event not detected                                                                              |
|      |                | 1     | Event detected                                                                                  |
| 14-9 | Reserved       |       | Reserved                                                                                        |
| 8    | CTRIPB7FLG     |       | CTRIPB7 latched output level flag. Synchronous with SYSCLK. Cleared with CTRIPB7FLGCLR.         |
|      |                | 0     | Event not detected                                                                              |
|      |                | 1     | Event detected                                                                                  |
| 7    | CTRIPOUTPFCSTS |       | CTRIPOUTPFC output status at last SYSCLK edge                                                   |
|      |                | 0     | Event not detected                                                                              |
|      |                | 1     | Event detected                                                                                  |
| 6-1  | Reserved       |       | Reserved                                                                                        |
| 0    | CTRIPB7STS     |       | CTRIPB7 output status at last SYSCLK edge                                                       |
|      |                | 0     | Event not detected                                                                              |
|      |                | 1     | Event detected                                                                                  |

# 7.9.4.10 CTRIP PFC Filter Output Flag Clear Register (CTRIPPFCFLGCLR)

The CTRIP PFC filter output flag clear register (CTRIPPFCFLGCLR) is shown and described in the figure and table below.

This register is EALLOW protected.

# Figure 7-35. CTRIP PFC Filter Output Flag Clear Register (CTRIPPFCFLGCLR)

| -                 |    | • •      |   | •             |
|-------------------|----|----------|---|---------------|
| 15                | 14 |          | 9 | 8             |
| CTRIPOUTPFCFLGCLR |    | Reserved |   | CTRIPB7FLGCLR |
| R/W1C             |    | R-0      |   | R/W1C         |
| 7                 |    |          |   | 0             |
|                   |    | Reserved |   |               |
|                   |    | R-0      |   |               |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 7-26. CTRIP PFC Filter Output Flag Clear Register (CTRIPPFCFLGCLR) Field Descriptions

| Bit  | Field             | Value | Description                                |
|------|-------------------|-------|--------------------------------------------|
| 15   | CTRIPOUTPFCFLGCLR |       | CTRIPOUTPFCFLG flag clear. Reads return 0. |
|      |                   | 0     | No effect                                  |
|      |                   | 1     | Clear CTRIPOUTPFCFLG                       |
| 14-9 | Reserved          |       | Reserved                                   |
| 8    | CTRIPB7FLGCLR     |       | CTRIPB7FLG flag clear. Reads return 0.     |
|      |                   | 0     | No effect                                  |
|      |                   | 1     | Clear CTRIPB7FLG                           |
| 7-0  | Reserved          |       | Reserved                                   |



# 7.9.5 LOCK Registers

**NOTE:** The following registers are all EALLOW protected.

### Table 7-27. LOCK Registers

| Name        | Address Range | Size (x16) | Description                                |
|-------------|---------------|------------|--------------------------------------------|
| LOCKCTRIP   | 0x64F0        | 1          | Lock Register for CTRIP Filters            |
| Reserved    | 0x64F1        | 1          | Reserved                                   |
| LOCKDAC     | 0x64F2        | 1          | Lock Register for DACs                     |
| Reserved    | 0x64F3        | 1          | Reserved                                   |
| LOCKAMPCOMP | 0x64F4        | 1          | Lock Register for Amplifiers & Comparators |
| Reserved    | 0x64F5        | 1          | Reserved                                   |
| LOCKSWITCH  | 0x64F6        | 1          | Lock Register for Switches                 |

# 7.9.5.1 Lock Register for CTRIP (LOCKCTRIP)

The lock register for CTRIP (LOCKCTRIP) is shown and described in the figure and table below. This register is EALLOW protected.

# Figure 7-36. Lock Register for CTRIP (LOCKCTRIP)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset; X = Determined by device type

# Table 7-28. Lock Register for CTRIP (LOCKCTRIP) Field Descriptions

| Bit  | Field        | Value | Description                                                                                                          |
|------|--------------|-------|----------------------------------------------------------------------------------------------------------------------|
| 15-3 | Reserved     |       | Reserved                                                                                                             |
| 2    | CTRIPPFCLOCK |       | Lock write-access to CTRIPPFC configuration and filter control registers (CTRIPxxICTL, CTRIPxxFILCTL, CTRIPPFCOCTL). |
|      |              | 0     | CTRIPPFC registers are unlocked. Write 0 has no effect.                                                              |
|      |              | 1     | CTRIPPFC registers are locked. Only a system reset can clear this bit.                                               |
| 1    | Reserved     |       | Reserved                                                                                                             |
| 0    | CTRIPM1LOCK  |       | Lock write-access to CTRIPM1 configuration and filter control registers (CTRIPxxICTL, CTRIPxxFILCTL, CTRIPM1OCTL).   |
|      |              | 0     | CTRIPM1 registers are unlocked. Write 0 has no effect.                                                               |
|      |              | 1     | CTRIPM1 registers are locked. Only a system reset can clear this bit.                                                |

# 7.9.5.2 Lock Register for DAC (LOCKDAC)

The lock register for DAC (LOCKDAC) is shown and described in the figure and table below.

This register is EALLOW protected.

# Figure 7-37. Lock Register for DAC (LOCKDAC)

| 15            |          |           |          |          |          |          | 8        |
|---------------|----------|-----------|----------|----------|----------|----------|----------|
|               |          |           | Rese     | erved    |          |          |          |
|               |          |           | R        | -0       |          |          |          |
| 7             | 6        | 5         | 4        | 3        | 2        | 1        | 0        |
| VREFOUTENLOCK | VREFLOCK | DACENLOCK | DAC5LOCK | Reserved | Reserved | DAC2LOCK | DAC1LOCK |
| R/W-0         | R/W-0    | R/W-0     | R/W-X    | R-1      | R-1      | R/W-0    | R/W-0    |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset; X = Determined by device type

# Table 7-29. Lock Register for DAC (LOCKDAC) Field Descriptions

| Bit  | Field         | Value | Description                                                   |
|------|---------------|-------|---------------------------------------------------------------|
| 15-8 | Reserved      |       | Reserved                                                      |
| 7    | VREFOUTENLOCK |       | Lock write-access to VREFOUT Enable Register (VREFOUTEN)      |
|      |               | 0     | VREFOUTEN is unlocked. Write 0 has no effect.                 |
|      |               | 1     | VREFOUTEN is locked. Only a system reset can clear this bit.  |
| 6    | VREFLOCK      |       | Lock write-access to VREFOUT Control Register (VREFOUTCTL)    |
|      |               | 0     | VREFOUTCTL is unlocked. Write 0 has no effect.                |
|      |               | 1     | VREFOUTCTL is locked. Only a system reset can clear this bit. |
| 5    | DACENLOCK     |       | Lock write-access to DACEN Register (DACEN)                   |
|      |               | 0     | DACEN is unlocked. Write 0 has no effect.                     |
|      |               | 1     | DACEN is locked. Only a system reset can clear this bit.      |
| 4    | DAC5LOCK      |       | Lock write-access to DAC5 Control Register (DAC5CTL)          |
|      |               | 0     | DAC5CTL is unlocked. Write 0 has no effect.                   |
|      |               | 1     | DAC5CTL is locked. Only a system reset can clear this bit.    |
| 3-2  | Reserved      |       | Reserved                                                      |
| 1    | DAC2LOCK      |       | Lock write-access to DAC2 Control Register (DAC2CTL)          |
|      |               | 0     | DAC2CTL is unlocked. Write 0 has no effect.                   |
|      |               | 1     | DAC2CTL is locked. Only a system reset can clear this bit.    |
| 0    | DAC1LOCK      |       | Lock write-access to DAC1 Control Register (DAC1CTL)          |
|      |               | 0     | DAC1CTL is unlocked. Write 0 has no effect.                   |
|      |               | 1     | DAC1CTL is locked. Only a system reset can clear this bit.    |



### 7.9.5.3 Lock Register for Amplifiers and Comparators (LOCKAMPCOMP)

The lock register for amplifiers and comparators (LOCKAMPCOMP) is shown and described in the figure and table below.

This register is EALLOW protected.

### Figure 7-38. Lock Register for Amplifiers and Comparators (LOCKAMPCOMP)

| 15 |          |   |              |             |             |            | 8         |
|----|----------|---|--------------|-------------|-------------|------------|-----------|
|    |          |   | Rese         | erved       |             |            |           |
|    |          |   | R            | -0          |             |            |           |
| 7  |          | 5 | 4            | 3           | 2           | 1          | 0         |
|    | Reserved |   | AMP_PFC_LOCK | AMP_M2_LOCK | AMP_M1_LOCK | COMPENLOCK | PGAENLOCK |
|    | R-0      |   | R/W-X        | R-1         | R/W-0       | R/W-0      | R/W-0     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset; X = Determined by device type

### Table 7-30. Lock Register for Amplifiers and Comparators (LOCKAMPCOMP) Field Descriptions

| Bit  | Field        | Value | Description                                                      |  |
|------|--------------|-------|------------------------------------------------------------------|--|
| 15-5 | Reserved     |       | Reserved                                                         |  |
| 4    | AMP_PFC_LOCK |       | Lock write-access to PFC AMP Gain Control Register (AMPPFC_GAIN) |  |
|      |              | 0     | AMPPFC_GAIN is unlocked. Write 0 has no effect.                  |  |
|      |              | 1     | AMPPFC_GAIN is locked. Only a system reset can clear this bit.   |  |
| 3    | AMP_M2_LOCK  |       | Lock write-access to M2 AMP Gain Control Register (AMPM2_GAIN)   |  |
|      |              | 0     | AMPM2_GAIN is unlocked. Write 0 has no effect.                   |  |
|      |              | 1     | AMPM2_GAIN is locked. Only a system reset can clear this bit.    |  |
| 2    | AMP_M1_LOCK  |       | Lock write-access to M1 AMP Gain Control Register (AMPM1_GAIN)   |  |
|      |              | 0     | AMPM1_GAIN is unlocked. Write 0 has no effect.                   |  |
|      |              | 1     | AMPM1_GAIN is locked. Only a system reset can clear this bit.    |  |
| 1    | COMPENLOCK   |       | Lock write-access to Comparator Enable Register (COMPEN)         |  |
|      |              | 0     | COMPEN is unlocked. Write 0 has no effect.                       |  |
|      |              | 1     | COMPEN is locked. Only a system reset can clear this bit.        |  |
| 0    | PGAENLOCK    |       | Lock write-access to PGA Enable Register (PGAEN)                 |  |
|      |              | 0     | PGAEN is unlocked. Write 0 has no effect.                        |  |
|      |              | 1     | PGAEN is locked. Only a system reset can clear this bit.         |  |

# 7.9.5.4 Lock Register for Switches (LOCKSWITCH)

The lock register for switches (LOCKSWITCH) is shown and described in the figure and table below.

This register is EALLOW protected.

# Figure 7-39. Lock Register for Switches (LOCKSWITCH)

| 15 |          |          |             |             | 8        |
|----|----------|----------|-------------|-------------|----------|
|    |          | Reserved |             |             |          |
|    |          | R-0      |             |             |          |
| 7  |          | 3        | 2           | 1           | 0        |
|    | Reserved |          | COMPHYSLOCK | ADCINSWLOCK | Reserved |
|    | R-0      |          | R/W-0       | R/W-0       | R-0      |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 7-31. Lock Register for Switches (LOCKSWITCH) Field Descriptions

| Bit  | Field       | Value | Description                                                    |
|------|-------------|-------|----------------------------------------------------------------|
| 15-3 | Reserved    |       | Reserved                                                       |
| 2    | COMPHYSLOCK |       | Lock write-access to COMPHYSTCTL register                      |
|      |             | 0     | COMPHYSTCTL is unlocked. Write 0 has no effect.                |
|      |             | 1     | COMPHYSTCTL is locked. Only a system reset can clear this bit. |
| 1    | ADCINSWLOCK |       | Lock write-access to ADCINSWITCH register                      |
|      |             | 0     | ADCINSWITCH is unlocked. Write 0 has no effect.                |
|      |             | 1     | ADCINSWITCH is locked. Only a system reset can clear this bit. |
| 0    | Reserved    |       | Reserved                                                       |



# **Control Law Accelerator (CLA)**

The control law accelerator (CLA) is an independent, fully-programmable, 32-bit floating-point math processor that brings concurrent control-loop exceuction to the C28x family. The low interrupt-latency of the CLA allows it to read ADC samples "just-in-time." This significantly reduces the ADC sample to output delay to enable faster system response and higher MHz control loops. By using the CLA to service time-critical control loops, the main CPU is free to perform other system tasks such as communications and diagnostics. This chapter provides an overview of the architectural structure and components of the control law accelerator.

### Topic

Page

| 8.1<br>8.2 | Control Law Accelerator (CLA) Overview |     |
|------------|----------------------------------------|-----|
| 8.3        | CLA Configuration and Debug            |     |
| 8.4        | Register Set                           |     |
| 8.5        | Pipeline                               | 537 |
| 8.6        | Instruction Set                        | 542 |
| 8.7        | Appendix A: CLA and CPU Arbitration    | 655 |



# 8.1 Control Law Accelerator (CLA) Overview

The control law accelerator extends the capabilities of the C28x CPU by adding parallel processing. Timecritical control loops serviced by the CLA can achieve low ADC sample to output delay. Thus, the CLA enables faster system response and higher frequency control loops. Utilizing the CLA for time-critical tasks frees up the main CPU to perform other system and communication functions concurrently. The following is a list of major features of the CLA.

- Clocked at the same rate as the main CPU (SYSCLKOUT).
- An independent architecture allowing CLA algorithm execution independent of the main C28x CPU.
  - Complete bus architecture:
    - Program address bus and program data bus
    - Data address bus, data read bus and data write bus
  - Independent eight stage pipeline.
  - 12-bit program counter (MPC)
  - Four 32-bit result registers (MR0-MR3)
  - Two 16-bit auxiliary registers (MAR0, MAR1)
  - Status register (MSTF)
- Instruction set includes:
  - IEEE single-precision (32-bit) floating point math operations
  - Floating-point math with parallel load or store
  - Floating-point multiply with parallel add or subtract
  - 1/X and 1/sqrt(X) estimations
  - Data type conversions.
  - Conditional branch and call
  - Data load/store operations
- The CLA program code can consist of up to eight tasks or interrupt service routines.
  - The start address of each task is specified by the MVECT registers.
  - No limit on task size as long as the tasks fit within the CLA program memory space.
  - One task is serviced at a time through to completion. There is no nesting of tasks.
  - Upon task completion a task-specific interrupt is flagged within the PIE.
  - When a task finishes the next highest-priority pending task is automatically started.
- Task trigger mechanisms:
  - C28x CPU via the IACK instruction
  - Task1 to Task7: the corresponding ADC, ePWM, eQEP, or eCAP module interrupt. For example:
    - Task1: ADCINT1 or EPWM1\_INT
    - Task2: ADCINT2 or EPWM2\_INT
    - Task 4: ADCINT4 or EPWM4\_INT or EQEP1\_INT or ECAP1\_INT
    - Task 7: ADCINT7 or EPWM7\_INT or EQEP1\_INT or ECAP1\_INT
  - Task8: ADCINT8 or CPU Timer 0 or EQEP1\_INT or ECAP1\_INT
- Memory and Shared Peripherals:
  - Two dedicated message RAMs for communication between the CLA and the main CPU.
  - The C28x CPU can map CLA program and data memory to the main CPU space or CLA space.
  - The CLA has direct access to the ePWM, Comparator and PGA (Analog subsystem), eCAP, eQEP, and ADC result registers.





A CLA data ROM is always mapped to CLA data space.



# 8.2 CLA Interface

This chapter describes how the C28x main CPU can interface to the CLA and vice versa.

# 8.2.1 CLA Memory

The CLA can access three types of memory: program, data and message RAMs. The behavior and arbitration for each type of memory is described in detail in Section 8.7.

# CLA Program Memory

At reset memory designated for CLA program is mapped to the main CPU memory and is treated like any other memory block. While mapped to CPU space, the main CPU can copy the CLA program code into the memory block. During debug the block can also be loaded directly by Code Composer Studio<sup>™</sup>.

Once the memory is initialized with CLA code, the main CPU maps it to the CLA program space by writing a 1 to the MMEMCFG[PROGE] bit. When mapped to the CLA program space, the block can only be accessed by the CLA for fetching opcodes. The main CPU can only perform debugger accesses when the CLA is either halted or idle. If the CLA is executing code, then all debugger accesses are blocked and the memory reads back all 0x0000.

CLA program memory is protected by the dual code security module (DCSM). All CLA program fetches are performed as 32-bit read operations and all opcodes must be aligned to an even address. Since all CLA opcodes are 32 bits, this alignment naturally occurs.

### CLA Data Memory

There are three CLA data RAM memory blocks and one CLA data ROM block on the device. At reset, all blocks are mapped to the main CPU memory space and treated by the CPU like any other memory block. While mapped to CPU space, the main CPU can initialize the memory with data tables and coefficients for the CLA to use.

Once the memory is initialized with CLA data the main CPU maps it to the CLA space. Each block can be individually mapped via the MMEMCFG[RAM0E], MMEMCFG[RAM1E] and MMEMCFG[RAM2E] bits. When mapped to the CLA data space, the memory can be accessed by either the CLA and/or the CPU for read or write operations by setting the appropriate memory configuration bits, MMEMCFG[RAMxE] and MMEMCFG[RAMxCPUE].

Each of the CLA data RAMs is protected by the DCSM module and emulation code security logic.

The CLA data RAMs should only be configured for Zone 1 security protection. If configured for Zone 2 security, the RAM blocks will be inaccessible by the CLA module. The CLA data ROM is factory-programmed with CLA math tables and is always mapped to the CLA data space. Like the data RAMs, it is protected by Zone 1 code security as well. More information about the DCSM module can be found in the *System Control and Interrupts* chapter, the DCSM section.

### • CLA Shared Message RAMs

There are two small memory blocks for data sharing and communication between the CLA and the main CPU. The message RAMs are always mapped to both CPU and CLA memory spaces and are protected by the DCSM. The message RAMs allow data accesses only; no program fetches can be performed.

### - CLA to CPU Message RAM

The CLA can use this block to pass data to the main CPU. This block is both readable and writable by the CLA. This block is also readable by the main CPU but writes by the main CPU are ignored.

### - CPU to CLA Message RAM

The main CPU can use this block to pass data and messages to the CLA. This message RAM is both readable and writable by the main CPU. The CLA can perform reads but writes by the CLA are ignored.



# 8.2.2 CLA Memory Bus

The CLA has dedicated bus architecture similar to that of the C28x CPU where there is a program read, data read and data write bus. Thus there can be simultaneous instruction fetch, data read and data write in a single cycle. Like the C28x CPU, the CLA expects memory logic to align any 32-bit read or write to an even address. If the address-generation logic generates an odd address, the CLA will begin reading or writing at the previous even address. This alignment does not affect the address values generated by the address-generation logic.

### CLA Program Bus

The CLA program bus has a access range of 2048 32-bit instructions. Since all CLA instructions are 32-bits, this bus always fetches 32-bits at a time and the opcodes must be even word aligned. The amount of program space available for the CLA is device dependent as described in the device-specific data manual.

### CLA Data Read Bus

The CLA data read bus has a 64K x 16 address range. The bus can perform 16 or 32-bit reads and will automatically stall if there are memory access conflicts. The data read bus has access to both the message RAMs, CLA data memory and the ePWM, Comparator and PGA (analog subsystem), eCAP, eQEP, and ADC result registers.

### CLA Data Write Bus

The CLA data write bus has a 64K x 16 address range. This bus can perform 16 or 32-bit writes. The bus will automatically stall if there are memory access conflicts. The data write bus has access to the CLA to CPU message RAM, CLA data memory and the ePWM, eCAP, eQEP, and Comparator and PGA (analog subsystem) registers.

# 8.2.3 Shared Peripherals and EALLOW Protection

The ePWM, Comparator and PGA (analog subsystem), eCAP, eQEP, and ADC result registers can be accessed by both the CLA and the main CPU. Section 8.5 describes in detail the CLA and CPU arbitration when both access these registers.

Several peripheral control registers are protected from spurious 28x CPU writes by the EALLOW protection mechanism. These same registers are also protected from spurious CLA writes. The EALLOW bit in the main CPU status register 1 (ST1) indicates the state of protection for the main CPU. Likewise the MEALLOW bit in the CLA status register (MSTF) indicates the state of write protection for the CLA. The MEALLOW CLA instruction enables write access by the CLA to EALLOW protected registers. Likewise the MEDIS CLA instruction will disable write access. This way the CLA can enable/disable write access independent of the main CPU.

The ADC offers the option to generate an early interrupt pulse when the ADC begins conversion. If this option is used to start a ADC triggered CLA task then the 8th instruction can read the result as soon as the conversion completes. The CLA pipeline activity for this scenario is shown in Section 8.5.



# 8.2.4 CLA Tasks and Interrupt Vectors

The CLA program code is divided up into tasks or interrupt service routines. Tasks do not have a fixed starting location or length. The CLA program memory can be divided up as desired. The CLA knows where a task begins by the content of the associated interrupt vector (MVECT1 to MVECT8) and the end is indicated by the MSTOP instruction.

The CLA supports 8 tasks. Task 1 has the highest priority and task 8 has the lowest priority. A task can be requested by a peripheral interrupt or by software:

### Peripheral interrupt trigger

Each task has specific interrupt sources that can trigger it. Configure the MPISRCSEL1 register to select from the potential sources. For example, task 1 (MVECT1) can be triggered by ADCINT1 or EPWM1\_INT as specified in MPISRCSEL1[PERINT1SEL]. You can not, however, trigger task 1 directly using EPWM2\_INT. If you need to trigger a task using EPWM2\_INT then the best solution is to use task 2 (MVECT2). Another possible solution is to take EPWM2\_INT with the main CPU and trigger a task with software.

To disable the peripheral from sending an interrupt request to the CLA set the PERINT1SEL option to no interrupt.

# • Software trigger

Tasks can also be started by the main CPU software writing to the MIFRC register or by the IACK instruction. Using the IACK instruction is more efficient because it does not require you to issue an EALLOW to set MIFR bits. Set the MCTL[IACKE] bit to enable the IACK feature. Each bit in the operand of the IACK instruction corresponds to a task. For example IACK #0x0001 will set bit 0 in the MIFR register to start task 1. Likewise IACK #0x0003 will set bits 0 and 1 in the MIFR register to start task 1 and task 2.

The CLA has its own fetch mechanism and can run and execute a task independent of the main CPU. Only one task is serviced at a time; there is no nesting of tasks. The task currently running is indicated in the MIRUN register. Interrupts that have been received but not yet serviced are indicated in the flag register (MIFR). If an interrupt request from a peripheral is received and that same task is already flagged, then the overflow flag bit is set. Overflow flags will remain set until they are cleared by the main CPU.

If the CLA is idle (no task is currently running) then the highest priority interrupt request that is both flagged (MIFR) and enabled (MIER) will start. The flow is as follows:

- 1. The associated RUN register bit is set (MIRUN) and the flag bit (MIFR) is cleared.
- 2. The CLA begins execution at the location indicated by the associated interrupt vector (MVECTx). MVECT is an offset from the first program memory location.
- 3. The CLA executes instructions until the MSTOP instruction is found. This indicates the end of the task.
- 4. The MIRUN bit is cleared.
- 5. The task-specific interrupt to the PIE is issued. This informs the main CPU that the task has completed.
- 6. The CLA returns to idle.

Once a task completes the next highest-priority pending task is automatically serviced and this sequence repeats.

# 8.3 CLA Configuration and Debug

This section discusses the steps necessary to configure and debug the CLA.

# 8.3.1 Building a CLA Application

The control law accelerator is programmed in CLA assembly code using the instructions described in Section 8.6. CLA assembly code can, and should, reside in the same project with C28x code. The only restriction is the CLA code must be in its own assembly section. This can be easily done using the .sect assembly directive. This does not prevent CLA and C28x code from being linked into the same memory region in the linker command file.

System and CLA initialization are performed by the main CPU. This would typically be done in C or C++ but can also include C28x assembly code. The main CPU will also copy the CLA code to the program memory and, if needed, initialize the CLA data RAM(s). Once system initialization is complete and the application begins, the CLA will service its interrupts using the CLA assembly code (or tasks). Concurrently the main CPU can perform other tasks.

The C2000 codegen tools V5.2.x and higher support CLA instructions when the following switch is set: -- cla\_support = cla0.

A CLA C-code compiler is available as of C2000 Code Gen Tools V6.1.x and higher, and Code Composer Studio v5.2.x and higher. The CLA C-code compiler recognizes files ending in the ".cla" extension as CLA-specific C-code.

# 8.3.2 Typical CLA Initialization Sequence

A typical CLA initialization sequence is performed by the main CPU as described in this section.

### 1. Copy CLA code into the CLA program RAM

The source for the CLA code can initially reside in the flash or a data stream from a communications peripheral or anywhere the main CPU can access it. The debugger can also be used to load code directly to the CLA program RAM during development.

### 2. Initialize CLA data RAM if necessary

Populate the CLA data RAM with any required data coefficients or constants.

### 3. Configure the CLA registers

Configure the CLA registers, but keep interrupts disabled until later (leave MIER == 0):

Enable the CLA clock in the appropriate PCLKCRx register.

The PCLKCRx register is defined in the device-specific system control and interrupts reference guide.

• Populate the CLA task interrupt vectors: MVECT1 to MVECT8.

Each vector needs to be initialized with the start address of the task to be executed when the CLA receives the associated interrupt. This address is an offset from the first address in CLA program memory. For example, 0x0000 corresponds to the first CLA program memory address.

### Select the task interrupt sources

For each task select the interrupt source in the PERINT1SEL register. If a task is going to be generated by software, select no interrupt.

### Enable IACK to start a task from software if desired

To enable the IACK instruction to start a task set the MCTL[IACKE] bit. Using the IACK instruction avoids having to set and clear the EALLOW bit.

### Map CLA data RAM(s) to CLA space if necessary

Map any of the data RAMs to the CLA space by writing a 1 to the respective MMEMCFG[RAMxE] bit. After the memory is mapped to CLA space, the main CPU has restricted access to it. Access control to the memory is determined by the combination of the memory configuration bits, MMEMCFG[RAMxE] and MMEMCFG[RAMxCPUE]. Allow two SYSCLKOUT cycles between changing the map configuration of this memory and accessing it.

### Map CLA program RAM to CLA space



Map the CLA program RAM to CLA space by setting the MMEMCFG[PROGE] bit. After the memory is remapped to CLA space the main CPU will only be able to make debug accesses to the memory block. Access control to the memory is determined by the combination of the memory configuration bits, MMEMCFG[RAMxE] and MMEMCFG[RAMxCPUE]. Allow two SYSCLKOUT cycles between changing the map configuration of these memories and accessing them.

### 4. Initialize the PIE vector table and registers

When a CLA task completes the associated interrupt in the PIE will be flagged. The CLA overflow and underflow flags also have associated interrupts within the PIE.

### 5. Enable CLA tasks/interrupts

Set appropriate bits in the interrupt enable register (MIER) to allow the CLA to service interrupts.

### 6. Initialize other peripherals

Initialize any peripherals (ePWM, ADC etc.) that will generate an interrupt to the CLA and be serviced by a CLA task.

The CLA is now ready to service interrupts and the message RAMs can be used to pass data between the CPU and the CLA. Typically mapping of the CLA program and data RAMs occurs only during the initialization process. If after some time the you want to re-map these memories back to CPU space then disable interrupts and make sure all tasks have completed by checking the MIRUN register. Always allow two SYSCLKOUT cycles when changing the map configuration of these memories and accessing them.



# 8.3.3 Debugging CLA Code

Debugging the CLA code is a simple process that occurs independently of the main CPU.

### 1. Insert a breakpoint in CLA code

Insert a CLA breakpoint (MDEBUGSTOP instruction) into the code where you want the CLA to halt, then rebuild and reload the code. Because the CLA does not flush its pipeline when you single-step, the MDEBUGSTOP instruction must be inserted as part of the code. The debugger cannot insert it as needed.

If CLA breakpoints are not enabled, then the MDEBUGSTOP will be ignored and is treated as a MNOP. The MDEBUGSTOP instruction can be placed anywhere in the CLA code as long as it is not within three instructions of a MBCNDD, MCCNDD, or MRCNDD instruction.

### 2. Enable CLA breakpoints

First, enable the CLA breakpoints in the debugger. In Code Composer Studio V3.3, this is done by connecting the CLA debug window (debug->connect). Breakpoints are disabled when this window is disconnected.

# 3. Start the task

There are three ways to start the task:

- The peripheral can assert an interrupt
- The main CPU can execute an IACK instruction, or
- You can manually write to the MIFRC register in the debugger window

When the task starts, the CLA will execute instructions until the MDEBUGSTOP is in the D2 phase of the pipeline. At this point, the CLA will halt and the pipeline will be frozen. The MPC register will reflect the address of the MDEBUGSTOP instruction.

# 4. Single-step the CLA code

Once halted, you can single-step the CLA code one cycle at a time. The behavior of a CLA single-step is different than the main C28x. When issuing a CLA single-step, the pipeline is clocked only one cycle and then again frozen. On the 28x CPU, the pipeline is flushed for each single-step.

You can also run to the next MDEBUGSTOP or to the end of the task. If another task is pending, it will automatically start when you run to the end of the task.

**NOTE:** When CLA program memory is mapped to the CLA memory space, a CLA fetch has higher priority than CPU debug reads. For this reason, it is possible for the CLA to permanently block CPU debug accesses if the CLA is executing in a loop. This might occur when initially developing CLA code due to a bug that causes an infinite loop. To avoid locking up the main CPU, the program memory will return all 0x0000 for CPU debug reads when the CLA is running. When the CLA is halted or idle then normal CPU debug read and write access to CLA program memory can be performed.

If the CLA gets caught in a infinite loop, you can use a soft or hard reset to exit the condition. A debugger reset will also exit the condition.

There are special cases that can occur when single-stepping a task such that the program counter, MPC, reaches the MSTOP instruction at the end of the task.

### • MPC halts at or after the MSTOP with a task already pending

If you are single-stepping or halted in "task A" and "task B" comes in before the MPC reaches the MSTOP, then "task B" will start if you continue to step through the MSTOP instruction. Basically if "task B" is pending before the MPC reaches MSTOP in "task A" then there is no issue in "task B" starting and no special action is required.

### MPC halts at or after the MSTOP with no task pending

In this case you have single-stepped or halted in "task A" and the MPC has reached the MSTOP with no tasks pending. If "task B" comes in at this point, it will be flagged in the MIFR register but it may or may not start if you continue to single-step through the MSTOP instruction of "task A."

It depends on exactly when the new task comes in. To reliably start "task B" perform a soft reset and reconfigure the MIER bits. Once this is done, you can start single-stepping "task B."

This case can be handled slightly differently if there is control over when "task B" comes in (for example using the IACK instruction to start the task). In this case you have single-stepped or halted in "task A" and the MPC has reached the MSTOP with no tasks pending. Before forcing "task B," run free to force the CLA out of the debug state. Once this is done you can force "task B" and continue debugging.

# 5. If desired, disable CLA breakpoints

In CCS V3.3 you can disable the CLA breakpoints by disconnecting the CLA debug window. Make sure to first issue a run or reset; otherwise, the CLA will be halted and no other tasks will start.

# 8.3.4 CLA Illegal Opcode Behavior

If the CLA fetches an opcode that does not correspond to a legal instruction, it will behave as follows:

- The CLA will halt with the illegal opcode in the D2 phase of the pipeline as if it were a breakpoint. This will occur whether CLA breakpoints are enabled or not.
- The CLA will issue the task-specific interrupt to the PIE.
- The MIRUN bit for the task will remain set.

Further single-stepping ignored once execution halts due to an illegal op-code. To exit this situation, issue either a soft or hard reset of the CLA as described in Section 8.3.5.

# 8.3.5 Resetting the CLA

There may be times when you need to reset the CLA. For example, during code debug the CLA may enter an infinite loop due to a code bug. The CLA has two types of resets: hard and soft. Both of these resets can be performed by the debugger or by the main CPU.

# Hard Reset

Writing a 1 to the MCTL[HARDRESET] bit will perform a hard reset of the CLA. The behavior of a hard reset is the same as a system reset (via  $\overline{XRS}$  or the debugger). In this case all CLA configuration and execution registers will be set to their default state and CLA execution will halt.

### Soft Reset

Writing a 1 to the MCTL[SOFTRESET] bit performs a soft reset of the CLA. If a task is executing it will halt and the associated MIRUN bit will be cleared. All bits within the interrupt enable (MIER) register will also be cleared so that no new tasks start.

# 8.4 Register Set

The CLA register set is independant from that of the main CPU. This chapter describes the CLA register set.

# 8.4.1 Register Memory Mapping

Table 8-1 describes the CLA module control and status register set.

| Name       | Offset | Size<br>(x16) | EALLOW | DCSM <sup>(1)</sup><br>Protected | Description                                   |
|------------|--------|---------------|--------|----------------------------------|-----------------------------------------------|
|            |        |               |        |                                  | Task Interrupt Vectors                        |
| MVECT1     | 0x0000 | 1             | Yes    | Yes                              | Task 1 Interrupt Vector                       |
| MVECT2     | 0x0001 | 1             | Yes    | Yes                              | Task 2 Interrupt Vector                       |
| MVECT3     | 0x0002 | 1             | Yes    | Yes                              | Task 3 Interrupt Vector                       |
| MVECT4     | 0x0003 | 1             | Yes    | Yes                              | Task 4 Interrupt Vector                       |
| MVECT5     | 0x0004 | 1             | Yes    | Yes                              | Task 5 Interrupt Vector                       |
| MVECT6     | 0x0005 | 1             | Yes    | Yes                              | Task 6 Interrupt Vector                       |
| MVECT7     | 0x0006 | 1             | Yes    | Yes                              | Task 7 Interrupt Vector                       |
| MVECT8     | 0x0007 | 1             | Yes    | Yes                              | Task 8 Interrupt Vector                       |
|            |        |               |        |                                  | Configuration Registers                       |
| MCTL       | 0x0010 | 1             | Yes    | Yes                              | Control Register                              |
| MMEMCFG    | 0x0011 | 1             | Yes    | Yes                              | Memory Configuration Register                 |
| MPISRCSEL1 | 0x0014 | 2             | Yes    | Yes                              | Peripheral Interrupt Source Select 1 Register |
| MIFR       | 0x0020 | 1             | Yes    | Yes                              | Interrupt Flag Register                       |
| MIOVF      | 0x0021 | 1             | Yes    | Yes                              | Interrupt Overflow Flag Register              |
| MIFRC      | 0x0022 | 1             | Yes    | Yes                              | Interrupt Force Register                      |
| MICLR      | 0x0023 | 1             | Yes    | Yes                              | Interrupt Flag Clear Register                 |
| MICLROVF   | 0x0024 | 1             | Yes    | Yes                              | Interrupt Overflow Flag Clear Register        |
| MIER       | 0x0025 | 1             | Yes    | Yes                              | Interrupt Enable Register                     |
| MIRUN      | 0x0026 | 1             | Yes    | Yes                              | Interrupt Run Status Register                 |
|            |        |               |        |                                  | Execution Registers <sup>(2)</sup>            |
| MPC        | 0x0028 | 1             | -      | Yes                              | CLA Program Counter                           |
| MAR0       | 0x0029 | 1             | -      | Yes                              | CLA Auxiliary Register 0                      |
| MAR1       | 0x002A | 1             | -      | Yes                              | CLA Auxiliary Register 1                      |
| MSTF       | 0x002E | 2             | -      | Yes                              | CLA Floating-Point Status Register            |
| MR0        | 0x0030 | 2             | -      | Yes                              | CLA Floating-Point Result Register 0          |
| MR1        | 0x0034 | 2             | -      | Yes                              | CLA Floating-Point Result Register 1          |
| MR2        | 0x0038 | 2             | -      | Yes                              | CLA Floating-Point Result Register 2          |
| MR3        | 0x003C | 2             | -      | Yes                              | CLA Floating-Point Result Register 3          |

<sup>(1)</sup> The CLA is protected by Zone 1 code security only.

<sup>(2)</sup> The main C28x CPU only has read access to the CLA execution registers for debug purposes. The main CPU cannot perform CPU or debugger writes to these registers.

# 8.4.2 Task Interrupt Vector Registers

Each CLA interrupt has its own interrupt vector (MVECT1 to MVECT8). This interrupt vector points to the first instruction of the associated task. When a task begins, the CLA will start fetching instructions at the location indicated by the appropriate MVECT register .

# 8.4.2.1 Task Interrupt Vector (MVECT1/2/3/4/5/6/7/8) Register

The task interrupt vector registers (MVECT1/2/3/4/5/6/7/8) are is shown in Section 8.4.2.1 and described in Figure 8-2.

# Figure 8-2. Task Interrupt Vector (MVECT1/2/3/4/5/6/7/8) Register

| - | 15 12    | 11    | 0 |
|---|----------|-------|---|
|   | Reserved | MVECT |   |
|   | R-0      | R-0   |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 8-2. Task Interrupt Vector (MVECT1/2/3/4/5/6/7/8) Field Descriptions

| Bits  | Name     | Value          | escription <sup>(1)</sup>                                                                                                                                                    |  |  |  |  |  |
|-------|----------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 15-12 | Reserved |                | Any writes to these bit(s) must always have a value of 0.                                                                                                                    |  |  |  |  |  |
| 11-0  | MVECT    | 0000 -<br>0FFF | set of the first instruction in the associated task from the start of CLA program space. The CLA legin instruction fetches from this location when the specific task begins. |  |  |  |  |  |
|       |          |                | For example: If CLA program memory begins at CPU address 0x009000 and the code for task 5 begins at CPU address 0x009120, then MVECT5 should be initialized with 0x0120.     |  |  |  |  |  |
|       |          |                | There is one MVECT register per task. Interrupt 1 uses MVECT1, interrupt 2 uses MVECT2 and so forth.                                                                         |  |  |  |  |  |

<sup>(1)</sup> These registers are protected by EALLOW and the dual code security module.

# 8.4.3 Configuration Registers

The configuration registers are described here.

# 8.4.3.1 Control Register (MCTL)

The configuration control register (MCTL) is shown in Figure 8-3 and described in Table 8-3.

# Figure 8-3. Control Register (MCTL)

| 15 |          |          |       |           | 8         |
|----|----------|----------|-------|-----------|-----------|
|    |          | Reserved |       |           |           |
|    |          | R -0     |       |           |           |
| 7  |          | 3        | 2     | 1         | 0         |
|    | Reserved |          | IACKE | SOFTRESET | HARDRESET |
|    | R/W-0    |          | R/W-0 | R/W-0     | R/W-0     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



| Bits | Name      | Value | Description <sup>(1)</sup>                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 15-3 | Reserved  |       | Any writes to these bit(s) must always have a value of 0.                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
| 2    | IACKE     |       | IACK enable                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|      |           | 0     | The CLA ignores the IACK instruction. (default)                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|      |           | 1     | Enable the main CPU to use the IACK #16bit instruction to set MIFR bits in the same manner as<br>writing to the MIFRC register. Each bit in the operand, #16bit, corresponds to a bit in the MIFRC<br>egister. Using IACK has the advantage of not having to first set the EALLOW bit. This allows the<br>main CPU to efficiently trigger a CLA task through software. |  |  |  |  |  |  |  |
|      |           |       | Examples IACK #0x0001 Write a 1 to MIFRC bit 0 to force task 1                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|      |           |       | IACK #0x0003 Write a 1 to MIFRC bit 0 and 1 to force task 1 and task 2                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
| 1    | SOFTRESET |       | Soft Reset                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|      |           | 0     | This bit always reads back 0 and writes of 0 are ignored.                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|      |           | 1     | Writing a 1 will cause a soft reset of the CLA. This will stop the current task, clear the MIRUN flag and clear all bits in the MIER register. After a soft reset you must wait at least 1 SYSCLKOUT cycle before reconfiguring the MIER bits. If these two operations are done back-to-back then the MIER bits will not get set.                                      |  |  |  |  |  |  |  |
| 0    | HARDRESET |       | Hard Reset                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|      |           | 0     | This bit always reads back 0 and writes of 0 are ignored.                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|      |           | 1     | Writing a 1 will cause a hard reset of the CLA. This will set all CLA registers to their default state.                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |

Table 8-3. Control Register (MCTL) Field Descriptions

<sup>(1)</sup> This register is protected by EALLOW and the dual code security module.



### 8.4.3.2 Memory Configuration Register (MMEMCFG)

The MMEMCFG register is used to map the CLA program and data RAMs to either the CPU or the CLA memory space. Typically mapping of the CLA program and data RAMs occurs only during the initialization process. If after some time the you want to re-map these memories back to CPU space then disable interrupts (MIER) and make sure all tasks have completed by checking the MIRUN register. Allow two SYSCLKOUT cycles between changing the map configuration of these memories and accessing them. Refer to Section 8.7 for CLA and CPU access arbitration details.

| Figure 6-4. Memory Configuration Register (MMEMCFG) |       |          |       |    |          |          |          |  |
|-----------------------------------------------------|-------|----------|-------|----|----------|----------|----------|--|
| 15                                                  |       |          |       | 11 | 10       | 9        | 8        |  |
|                                                     |       | Reserved |       |    | RAM2CPUE | RAM1CPUE | RAM0CPUE |  |
|                                                     |       | R -0     |       |    | R/W-0    | R/W-0    | R/W-0    |  |
| 7                                                   | 6     | 5        | 4     | 3  |          | 1        | 0        |  |
| Reserved                                            | RAM2E | RAM1E    | RAM0E |    | Reserved |          | PROGE    |  |
| R-0                                                 | R/W-0 | R/W-0    | R/W-0 |    | R-0      |          | R/W-0    |  |

# Figure 8-4. Memory Configuration Register (MMEMCFG)

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 8-4. Memory Configuration Register (MMEMCFG) Field Descriptions

| Bits  | Field    | Value | Description                                                                                                    |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------------|
| 15-11 | Reserved |       | Any writes to these bit(s) must always have a value of 0                                                       |
| 10    | RAM2CPUE |       | CLA Data RAM 2 CPU Access Enable Bit:                                                                          |
|       |          |       | Allow two SYSCLKOUT cycles between changing this bit and accessing the memory                                  |
|       |          | 0     | RAM2E = 0, CPU data accesses to CLA Data RAM 2 are always allowed                                              |
|       |          |       | RAM2E = 1, CPU data accesses to CLA Data RAM 2 are not allowed                                                 |
|       |          | 1     | RAM2E = 0, CPU data accesses to CLA Data RAM 2 are always allowed                                              |
|       |          |       | RAM2E = 1, CPU data accesses to CLA Data RAM 2 are allowed                                                     |
| 9     | RAM1CPUE |       | CLA Data RAM 1 CPU Access Enable Bit:                                                                          |
|       |          |       | Allow two SYSCLKOUT cycles between changing this bit and accessing the memory                                  |
|       |          | 0     | RAM1E = 0, CPU data accesses to CLA Data RAM 1 are always allowed                                              |
|       |          |       | RAM1E = 1, CPU data accesses to CLA Data RAM 1 are not allowed                                                 |
|       |          | 1     | RAM1E = 0, CPU data accesses to CLA Data RAM 1 are always allowed                                              |
|       |          |       | RAM1E = 1, CPU data accesses to CLA Data RAM 1 are allowed                                                     |
| 8     | RAM0CPUE |       | CLA Data RAM 0 CPU Access Enable Bit:                                                                          |
|       |          |       | Allow two SYSCLKOUT cycles between changing this bit and accessing the memory                                  |
|       |          | 0     | RAM0E = 0, CPU data accesses to CLA Data RAM 0 are always allowed                                              |
|       |          |       | RAM0E = 1, CPU data accesses to CLA Data RAM 0 are not allowed                                                 |
|       |          | 1     | RAM0E = 0, CPU data accesses to CLA Data RAM 0 are always allowed                                              |
|       |          |       | RAM0E = 1, CPU data accesses to CLA Data RAM 0 are allowed                                                     |
| 7     | Reserved |       | Any writes to these bit(s) must always have a value of 0                                                       |
| 6     | RAM2E    |       | CLA Data RAM 2 Enable                                                                                          |
|       |          |       | Allow two SYSCLKOUT cycles between changing this bit and accessing the memory                                  |
|       |          | 0     | CLA data SARAM block 2 is mapped to the main CPU program and data space. CLA reads will return zero. (default) |
|       |          | 1     | CLA data SARAM block 2 is mapped to the CLA space. The RAM2CPUE bit determines the CPU access to this memory   |
| 5     | RAM1E    |       | CLA Data RAM 1 Enable                                                                                          |
|       |          |       | Allow two SYSCLKOUT cycles between changing this bit and accessing the memory                                  |
|       |          | 0     | CLA data SARAM block 1 is mapped to the main CPU program and data space. CLA reads will return zero. (default) |
|       |          | 1     | CLA data SARAM block 1 is mapped to the CLA space. The RAM1CPUE bit determines the CPU access to this memory   |

| Bits  | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4     | RAM0E    |       | CLA Data RAM 0 Enable                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |          |       | Allow two SYSCLKOUT cycles between changing this bit and accessing the memory                                                                                                                                                                                                                                                                                                                                                                      |
|       |          | 0     | CLA data SARAM block 0 is mapped to the main CPU program and data space. CLA reads will return zero. (default)                                                                                                                                                                                                                                                                                                                                     |
|       |          | 1     | CLA data SARAM block 0 is mapped to the CLA space. The RAM0CPUE bit determines the CPU access to this memory                                                                                                                                                                                                                                                                                                                                       |
| 3 - 1 | Reserved |       | Any writes to these bit(s) must always have a value of 0                                                                                                                                                                                                                                                                                                                                                                                           |
| 0     | PROGE    |       | CLA Program Space Enable                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          |       | Allow two SYSCLKOUT cycles between changing this bit and accessing the memory                                                                                                                                                                                                                                                                                                                                                                      |
|       |          | 0     | CLA program SARAM is mapped to the main CPU program and data space. If the CLA attempts a program fetch the result will be the same as an illegal opcode fetch as described in Section 3.4.(default)                                                                                                                                                                                                                                               |
|       |          | 1     | CLA program SARAM is mapped to the CLA program space. The main SPU can only make debug accesses to this block                                                                                                                                                                                                                                                                                                                                      |
|       |          |       | In this state the CLA has higher priority than CPU debug reads. It is, therefore, possible for the CLA to permanently block debug accesses if the CLA is executing in a loop. This might occur when if the CLA code has a bug. To avoid this issue, the program memory will reutrn 0x0000 for CPU debug reads (ignore writes) when the CLA is running. When the CLA is halted or idle then normal CPU debug read and write access can be performed |

# Table 8-4. Memory Configuration Register (MMEMCFG) Field Descriptions (continued)

# 8.4.3.3 CLA Peripheral Interrupt Source Select 1 Register (MPISRCSEL1)

Each task has specific peripherals that can start it. For example, Task2 can be started by ADCINT2 or EPWM2\_INT. To configure which of the possible peripherals will start a task configure the MPISRCSEL1 register shown in Figure 8-5. Choosing the option "no interrupt source" means that only the main CPU software will be able to start the given task.

### Figure 8-5. CLA Peripheral Interrupt Source Select 1 Register (MPISRCSEL1)

| 0          |       |            | •     | •          | •           | •          | ,        |
|------------|-------|------------|-------|------------|-------------|------------|----------|
| 31         | 28    | 27         | 24    | 23         | 20          | 19         | 16       |
| PERINT8SEL |       | PERINT7SEL |       | PE         | PERINT6SEL  |            | RINT5SEL |
| F          | R/W-0 | R/W-0      |       |            | R/W-0 R/W-0 |            | R/W-0    |
| 15         | 12    | 11         | 8     | 7          | 4           | 3          | 0        |
| PERINT4SEL |       | PERINT3SEL |       | PERINT2SEL |             | PERINT1SEL |          |
| R/W-0      |       | F          | R/W-0 |            | R/W-0       |            | R/W-0    |
|            |       | <b>.</b>   |       |            |             |            |          |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 8-5. Peripheral Interrupt Source Select 1 (MPISRCSEL1) Register Field Descriptions

| Bits    | Field      | Value <sup>(1)</sup> | Description <sup>(2)</sup>                             |
|---------|------------|----------------------|--------------------------------------------------------|
| 31 - 28 | PERINT8SEL |                      | Task 8 Peripheral Interrupt Input Select               |
|         |            | 0000                 | ADCINT8 is the input for interrupt task 8. (default)   |
|         |            | 0010                 | CPU Timer 0 is the input for interrupt task 8. (TINT0) |
|         |            | 0100                 | eQEP1 is the input for interrupt task 8. (EQEP1_INT)   |
|         |            | 0101                 | No interrupt source for task 8.                        |
|         |            | 1000                 | eCAP1 is the input for interrupt task 8. (ECAP1_INT)   |
|         |            | Other                | No interrupt source for task 8.                        |

<sup>(1)</sup> All values not shown are reserved.

<sup>(2)</sup> This register is protected by EALLOW and the dual code security module.

### Table 8-5. Peripheral Interrupt Source Select 1 (MPISRCSEL1) Register Field Descriptions (continued)

| Bits    | Field      | Value <sup>(1)</sup> | Description <sup>(2)</sup>                           |
|---------|------------|----------------------|------------------------------------------------------|
| 27 - 24 | PERINT7SEL |                      | Task 7 Peripheral Interrupt Input Select             |
|         |            | 0000                 | ADCINT7 is the input for interrupt task 7. (default) |
|         |            | 0010                 | ePWM7 is the input for interrupt task 7. (EPWM7_INT) |
|         |            | 0100                 | eQEP1 is the input for interrupt task 7. (EQEP1_INT) |
|         |            | 0101                 | No interrupt source for task 7.                      |
|         |            | 1000                 | eCAP1 is the input for interrupt task 7. (ECAP1_INT) |
|         |            | Other                | No interrupt source for task 7.                      |
| 23 - 20 | PERINT6SEL |                      | Task 6 Peripheral Interrupt Input Select             |
|         |            | 0000                 | ADCINT6 is the input for interrupt task 6. (default) |
|         |            | 0010                 | ePWM6 is the input for interrupt task 6. (EPWM6_INT) |
|         |            | 0100                 | eQEP1 is the input for interrupt task 6. (EQEP1_INT) |
|         |            | 0101                 | No interrupt source for task 6.                      |
|         |            | 1000                 | eCAP1 is the input for interrupt task 6. (ECAP1_INT) |
|         |            | Other                | No interrupt source for task 6.                      |
| 19 - 16 | PERINT5SEL |                      | Task 5 Peripheral Interrupt Input Select             |
|         |            | 0000                 | ADCINT5 is the input for interrupt task 5. (default) |
|         |            | 0010                 | ePWM5 is the input for interrupt task 5. (EPWM5_INT) |
|         |            | 0100                 | eQEP1 is the input for interrupt task 5. (EQEP1_INT) |
|         |            | 0101                 | No interrupt source for task 5.                      |
|         |            | 1000                 | eCAP1 is the input for interrupt task 5. (ECAP1_INT) |
|         |            | Other                | No interrupt source for task 5.                      |
| 15 - 12 | PERINT4SEL |                      | Task 4 Peripheral Interrupt Input Select             |
|         |            | 0000                 | ADCINT4 is the input for interrupt task 4. (default) |
|         |            | 0010                 | ePWM4 is the input for interrupt task 4. (EPWM4_INT) |
|         |            | 0100                 | eQEP1 is the input for interrupt task 4. (EQEP1_INT) |
|         |            | 0101                 | No interrupt source for task 4.                      |
|         |            | 1000                 | eCAP1 is the input for interrupt task 4. (ECAP1_INT) |
|         |            | Other                | No interrupt source for task 4.                      |
| 11 - 8  | PERINT3SEL |                      | Task 3 Peripheral Interrupt Input Select             |
|         |            | 0000                 | ADCINT3 is the input for interrupt task 3. (default) |
|         |            | 0010                 | ePWM3 is the input for interrupt task 3. (EPWM3_INT) |
|         |            | xxx1                 | No interrupt source for task 3.                      |
| 7 - 4   | PERINT2SEL |                      | Task 2 Peripheral Interrupt Input Select             |
|         |            | 0000                 | ADCINT2 is the input for interrupt task 2. (default) |
|         |            | 0010                 | ePWM2 is the input for interrupt task 2. (EPWM2_INT) |
|         |            | xxx1                 | No interrupt source for task 2.                      |
| 3 - 0   | PERINT1SEL |                      | Task 1Peripheral Interrupt Input Select              |
|         |            | 0000                 | ADCINT1 is the input for interrupt task 1. (default) |
|         |            | 0010                 | ePWM1 is the input for interrupt task 1. (EPWM1_INT) |
|         |            | xxx1                 | No interrupt source                                  |

# 8.4.3.4 Interrupt Enable Register (MIER)

Setting the bits in the interrupt enable register (MIER) allow an incoming interrupt or main CPU software to start the corresponding CLA task. Writing a 0 will block the task, but the interrupt request will still be latched in the flag register (MIFLG). Setting the MIER register bit to 0 while the corresponding task is executing will have no effect on the task. The task will continue to run until it hits the MSTOP instruction.

When a soft reset is issued, the MIER bits are cleared. There should always be at least a 1 SYSCLKOUT delay between issuing the soft reset and reconfiguring the MIER bits.

| 15    |       |       |       |       |       |       | 8     |  |  |
|-------|-------|-------|-------|-------|-------|-------|-------|--|--|
|       |       |       | Rese  | erved |       |       |       |  |  |
|       | R -0  |       |       |       |       |       |       |  |  |
| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |  |  |
| INT8  | INT7  | INT6  | INT5  | INT4  | INT3  | INT2  | INT1  |  |  |
| R/W-0 |  |  |

### Figure 8-6. Interrupt Enable Register (MIER)

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bits | Name     | Value | Description <sup>(1)</sup>                                |
|------|----------|-------|-----------------------------------------------------------|
| 15-8 | Reserved |       | Any writes to these bit(s) must always have a value of 0. |
| 7    | INT8     |       | Task 8 Interrupt Enable                                   |
|      |          | 0     | Task 8 interrupt is disabled. (default)                   |
|      |          | 1     | Task 8 interrupt is enabled.                              |
| 6    | INT7     |       | Task 7 Interrupt Enable                                   |
|      |          | 0     | Task 7 interrupt is disabled. (default)                   |
|      |          | 1     | Task 7 interrupt is enabled.                              |
| 5    | INT6     |       | Task 6 Interrupt Enable                                   |
|      |          | 0     | Task 6 interrupt is disabled. (default)                   |
|      |          | 1     | Task 6 interrupt is enabled.                              |
| 4    | INT5     |       | Task 5 Interrupt Enable                                   |
|      |          | 0     | Task 5 interrupt is disabled. (default)                   |
|      |          | 1     | Task 5 interrupt is enabled.                              |
| 3    | INT4     |       | Task 4 Interrupt Enable                                   |
|      |          | 0     | Task 4 interrupt is disabled. (default)                   |
|      |          | 1     | Task 4 interrupt is enabled.                              |
| 2    | INT3     |       | Task 3 Interrupt Enable                                   |
|      |          | 0     | Task 3 interrupt is disabled. (default)                   |
|      |          | 1     | Task 3 interrupt is enabled.                              |
| 1    | INT2     |       | Task 2 Interrupt Enable                                   |
|      |          | 0     | Task 2 interrupt is disabled. (default)                   |
|      |          | 1     | Task 2 interrupt is enabled.                              |
| 0    | INT1     |       | Task 1 Interrupt Enable                                   |
|      |          | 0     | Task 1 interrupt is disabled. (default)                   |
|      |          | 1     | Task 1 interrupt is enabled.                              |

# Table 8-6. Interrupt Enable Register (MIER) Field Descriptions

<sup>(1)</sup> This register is protected by EALLOW and the dual code security module.

# 8.4.3.5 Interrupt Flag Register (MIFR)

Each bit in the interrupt flag register corresponds to a CLA task. The corresponding bit is automatically set when the task request is received from the peripheral interrupt. The bit can also be set by the main CPU writing to the MIFRC register or using the IACK instruction to start the task. To use the IACK instruction to begin a task first enable this feature in the MCTL register. If the bit is already set when a new peripheral interrupt is received, then the corresponding overflow bit will be set in the MIOVF register.

The corresponding MIFR bit is automatically cleared when the task begins execution. This will occur if the interrupt is enabled in the MIER register and no other higher priority task is pending. The bits can also be cleared manually by writing to the MICLR register. Writes to the MIFR register are ignored.



Register Set

Figure 8-7. Interrupt Flag Register (MIFR) 15 8 Reserved R -0 7 6 5 4 3 2 1 0 INT8 INT7 INT6 INT5 INT4 INT3 INT2 INT1 R-0 R-0 R-0 R-0 R-0 R-0 R-0 R-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bits | Name     | Value | Description <sup>(1)</sup>                                     |
|------|----------|-------|----------------------------------------------------------------|
| 15-8 | Reserved |       | Any writes to these bit(s) must always have a value of 0.      |
| 7    | INT8     |       | Task 8 Interrupt Flag                                          |
|      |          | 0     | A task 8 interrupt is currently not flagged. (default)         |
|      |          | 1     | A task 8 interrupt has been received and is pending execution. |
| 6    | INT7     |       | Task 7 Interrupt Flag                                          |
|      |          | 0     | A task 7 interrupt is currently not flagged. (default)         |
|      |          | 1     | A task 7 interrupt has been received and is pending execution. |
| 5    | INT6     |       | Task 6 Interrupt Flag                                          |
|      |          | 0     | A task 6 interrupt is currently not flagged. (default)         |
|      |          | 1     | A task 6 interrupt has been received and is pending execution. |
| 4    | INT5     |       | Task 5 Interrupt Flag                                          |
|      |          | 0     | A task 5 interrupt is currently not flagged. (default)         |
|      |          | 1     | A task 5 interrupt has been received and is pending execution. |
| 3    | INT4     |       | Task 4 Interrupt Flag                                          |
|      |          | 0     | A task 4 interrupt is currently not flagged. (default)         |
|      |          | 1     | A task 4 interrupt has been received and is pending execution. |
| 2    | INT3     |       | Task 3 Interrupt Flag                                          |
|      |          | 0     | A task 3 interrupt is currently not flagged. (default)         |
|      |          | 1     | A task 3 interrupt has been received and is pending execution. |
| 1    | INT2     |       | Task 2 Interrupt Flag                                          |
|      |          | 0     | A task 2 interrupt is currently not flagged. (default)         |
|      |          | 1     | A task 2 interrupt has been received and is pending execution. |
| 0    | INT1     |       | Task 1 Interrupt Flag                                          |
|      |          | 0     | A task 1 interrupt is currently not flagged. (default)         |
|      |          | 1     | A task 1 interrupt has been received and is pending execution. |

### Table 8-7. Interrupt Flag Register (MIFR) Field Descriptions

<sup>(1)</sup> This register is protected by the dual code security module.

# 8.4.3.6 Interrupt Overflow Flag Register (MIOVF)

Each bit in the overflow flag register corresponds to a CLA task. The bit is set when an interrupt overflow event has occurred for the specific task. An overflow event occurs when the MIFR register bit is already set when a new interrupt is received from a peripheral source. The MIOVF bits are only affected by peripheral interrupt events. They do not respond to a task request by the main CPU IACK instruction or by directly setting MIFR bits. The overflow flag will remain latched and can only be cleared by writing to the overflow flag clear (MICLROVF) register. Writes to the MIOVF register are ignored.

Register Set

| Figure 8-8. Interrupt Overflow Flag Register (MIOVF) |      |      |      |       |      |      |      |  |
|------------------------------------------------------|------|------|------|-------|------|------|------|--|
| 15                                                   |      |      |      |       |      |      |      |  |
|                                                      |      |      | Res  | erved |      |      |      |  |
| R -0                                                 |      |      |      |       |      |      |      |  |
| 7                                                    | 6    | 5    | 4    | 3     | 2    | 1    | 0    |  |
| INT8                                                 | INT7 | INT6 | INT5 | INT4  | INT3 | INT2 | INT1 |  |
| R-0                                                  | R-0  | R-0  | R-0  | R-0   | R-0  | R-0  | R-0  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 8-8. Interrupt Overflow Flag Register (MIOVF) Field Descriptions

| Bits | Name     | Value | Description <sup>(1)</sup>                                |
|------|----------|-------|-----------------------------------------------------------|
| 15-8 | Reserved |       | Any writes to these bit(s) must always have a value of 0. |
| 7    | INT8     |       | Task 8 Interrupt Overflow Flag                            |
|      |          | 0     | A task 8 interrupt overflow has not occurred. (default)   |
|      |          | 1     | A task 8 interrupt overflow has occurred.                 |
| 6    | INT7     |       | Task 7 Interrupt Overflow Flag                            |
|      |          | 0     | A task 7 interrupt overflow has not occurred. (default)   |
|      |          | 1     | A task 7 interrupt overflow has occurred.                 |
| 5    | INT6     |       | Task 6 Interrupt Overflow Flag                            |
|      |          | 0     | A task 6 interrupt overflow has not occurred. (default)   |
|      |          | 1     | A task 6 interrupt overflow has occurred.                 |
| 4    | INT5     |       | Task 5 Interrupt Overflow Flag                            |
|      |          | 0     | A task 5 interrupt overflow has not occurred. (default)   |
|      |          | 1     | A task 5 interrupt overflow has occurred.                 |
| 3    | INT4     |       | Task 4 Interrupt Overflow Flag                            |
|      |          | 0     | A task 4 interrupt overflow has not occurred. (default)   |
|      |          | 1     | A task 4 interrupt overflow has occurred.                 |
| 2    | INT3     |       | Task 3 Interrupt Overflow Flag                            |
|      |          | 0     | A task 3 interrupt overflow has not occurred. (default)   |
|      |          | 1     | A task 3 interrupt overflow has occurred.                 |
| 1    | INT2     |       | Task 2 Interrupt Overflow Flag                            |
|      |          | 0     | A task 2 interrupt overflow has not occurred. (default)   |
|      |          | 1     | A task 2 interrupt overflow has occurred.                 |
| 0    | INT1     |       | Task 1 Interrupt Overflow Flag                            |
|      |          | 0     | A task 1 interrupt overflow has not occurred. (default)   |
|      |          | 1     | A task 1 interrupt overflow has occurred.                 |

<sup>(1)</sup> This register is protected by the dual code security module.

# 8.4.3.7 Interrupt Run Status Register (MIRUN)

The interrupt run status register (MIRUN) indicates which task is currently executing. Only one MIRUN bit will ever be set to a 1 at any given time. The bit is automatically cleared when the task competes and the respective interrupt is fed to the peripheral interrupt expansion (PIE) block of the device. This lets the main CPU know when a task has completed. The main CPU can stop a currently running task by writing to the MCTL[SOFTRESET] bit. This will clear the MIRUN flag and stop the task. In this case no interrupt will be generated to the PIE.



Register Set

www.ti.com

| Figure 8-9. Interrupt Run Status Register (MIRUN) |      |      |      |       |      |      |      |
|---------------------------------------------------|------|------|------|-------|------|------|------|
| 15                                                |      | -    | -    |       |      | -    | 8    |
|                                                   |      |      | Res  | erved |      |      |      |
| R -0                                              |      |      |      |       |      |      |      |
| 7                                                 | 6    | 5    | 4    | 3     | 2    | 1    | 0    |
| INT8                                              | INT7 | INT6 | INT5 | INT4  | INT3 | INT2 | INT1 |
| R-0                                               | R-0  | R-0  | R-0  | R-0   | R-0  | R-0  | R-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Table 8-9. Interrupt Run Status Register (MIRUN) Field Description |
|--------------------------------------------------------------------|
|--------------------------------------------------------------------|

| Bits | Name     | Value | Description <sup>(1)</sup>                                |
|------|----------|-------|-----------------------------------------------------------|
| 15-8 | Reserved |       | Any writes to these bit(s) must always have a value of 0. |
| 7    | INT8     |       | Task 8 Run Status                                         |
|      |          | 0     | Task 8 is not executing. (default)                        |
|      |          | 1     | Task 8 is executing.                                      |
| 6    | INT7     |       | Task 7 Run Status                                         |
|      |          | 0     | Task 7 is not executing. (default)                        |
|      |          | 1     | Task 7 is executing.                                      |
| 5    | INT6     |       | Task 6 Run Status                                         |
|      |          | 0     | Task 6 is not executing. (default)                        |
|      |          | 1     | Task 6 is executing.                                      |
| 4    | INT5     |       | Task 5 Run Status                                         |
|      |          | 0     | Task 5 is not executing. (default)                        |
|      |          | 1     | Task 5 is executing.                                      |
| 3    | INT4     |       | Task 4 Run Status                                         |
|      |          | 0     | Task 4 is not executing. (default)                        |
|      |          | 1     | Task 4 is executing.                                      |
| 2    | INT3     |       | Task 3 Run Status                                         |
|      |          | 0     | Task 3 is not executing. (default)                        |
|      |          | 1     | Task 3 is executing.                                      |
| 1    | INT2     |       | Task 2 Run Status                                         |
|      |          | 0     | Task 2 is not executing. (default)                        |
|      |          | 1     | Task 2 is executing.                                      |
| 0    | INT1     |       | Task 1 Run Status                                         |
|      |          | 0     | Task 1 is not executing. (default)                        |
|      |          | 1     | Task 1 is executing.                                      |

<sup>(1)</sup> This register is protected by the dual code security module.

### 8.4.3.8 Interrupt Force Register (MIFRC)

The interrupt force register can be used by the main CPU to start tasks through software. Writing a 1 to a MIFRC bit will set the corresponding bit in the MIFR register. Writes of 0 are ignored and reads always return 0. The IACK #16bit operation can also be used to start tasks and has the same effect as the MIFRC register. To enable IACK to set MIFR bits you must first set the MCTL[IACKE] bit. Using IACK has the advantage of not having to first set the EALLOW bit. This allows the main CPU to efficiently trigger CLA tasks through software.

#### Figure 8-10. Interrupt Force Register (MIFRC) 15 8 Reserved R -0 7 6 5 4 3 2 1 0 INT8 INT7 INT6 INT5 INT4 INT2 INT3 INT1 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 8-10. Interrupt Force Register (MIFRC) Field Descriptions

| Bits | Name     | Value | Description <sup>(1)</sup>                                   |
|------|----------|-------|--------------------------------------------------------------|
| 15-8 | Reserved |       | Any writes to these bit(s) must always have a value of 0.    |
| 7    | INT8     |       | Task 8 Interrupt Force                                       |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to force the task 8 interrupt.                     |
| 6    | INT7     |       | Task 7 Interrupt Force                                       |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to force the task 7 interrupt.                     |
| 5    | INT6     |       | Task 6 Interrupt Force                                       |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to force the task 6 interrupt.                     |
| 4    | INT5     |       | Task 5 Interrupt Force                                       |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to force the task 5 interrupt.                     |
| 3    | INT4     |       | Task 4 Interrupt Force                                       |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to force the task 4 interrupt.                     |
| 2    | INT3     |       | Task 3 Interrupt Force                                       |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to force the task 3 interrupt.                     |
| 1    | INT2     |       | Task 2 Interrupt Force                                       |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to force the task 2 interrupt.                     |
| 0    | INT1     |       | Task 1 Interrupt Force                                       |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to force the task 1 interrupt.                     |

<sup>1)</sup> This register is protected by EALLOW and the dual code security module.



### 8.4.3.9 Interrupt Flag Clear Register (MICLR)

Normally bits in the MIFR register are automatically cleared when a task begins. The interrupt flag clear register can be used to instead manually clear bits in the interrupt flag (MIFR) register. Writing a 1 to a MICLR bit will clear the corresponding bit in the MIFR register. Writes of 0 are ignored and reads always return 0.

| 15    |       |       |       |       |       |       | 8     |
|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       |       | Res   | erved |       |       |       |
|       | R -0  |       |       |       |       |       |       |
| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| INT8  | INT7  | INT6  | INT5  | INT4  | INT3  | INT2  | INT1  |
| R/W-0 |

# Figure 8-11. Interrupt Flag Clear Register (MICLR)

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 8-11. Interrupt Flag Clear Register (MICLR) Field Descriptions

| Bits | Name     | Value | Description <sup>(1)</sup>                                   |
|------|----------|-------|--------------------------------------------------------------|
| 15-8 | Reserved |       | Any writes to these bit(s) must always have a value of 0.    |
| 7    | INT8     |       | Task 8 Interrupt Flag Clear                                  |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 8 interrupt flag.                |
| 6    | INT7     |       | Task 7 Interrupt Flag Clear                                  |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 7 interrupt flag.                |
| 5    | INT6     |       | Task 6 Interrupt Flag Clear                                  |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 6 interrupt flag.                |
| 4    | INT5     |       | Task 5 Interrupt Flag Clear                                  |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 5 interrupt flag.                |
| 3    | INT4     |       | Task 4 Interrupt Flag Clear                                  |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 4 interrupt flag.                |
| 2    | INT3     |       | Task 3 Interrupt Flag Clear                                  |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 3 interrupt flag.                |
| 1    | INT2     |       | Task 2 Interrupt Flag Clear                                  |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 2 interrupt flag.                |
| 0    | INT1     |       | Task 1 Interrupt Flag Clear                                  |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 1 interrupt flag.                |

<sup>(1)</sup> This register is protected by EALLOW and the dual code security module.

# 8.4.3.10 Interrupt Overflow Flag Clear Register (MICLROVF)

Overflow flag bits in the MIOVF register are latched until manually cleared using the MICLROVF register. Writing a 1 to a MICLROVF bit will clear the corresponding bit in the MIOVF register. Writes of 0 are ignored and reads always return 0.

# Figure 8-12. Interrupt Overflow Flag Clear Register (MICLROVF)

| 15    |            |                       |       |       |       |       | 8     |
|-------|------------|-----------------------|-------|-------|-------|-------|-------|
|       |            |                       | Rese  | erved |       |       |       |
| R -0  |            |                       |       |       |       |       |       |
| 7     | 6          | 5                     | 4     | 3     | 2     | 1     | 0     |
| INT8  | INT7       | INT6                  | INT5  | INT4  | INT3  | INT2  | INT1  |
| R/W-0 | R/W-0      | R/W-0                 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|       | Des 1/4/21 | Desident and a second | - 1   |       |       |       |       |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 8-12. Interrupt Overflow Flag Clear Register (MICLROVF) Field Descriptions

| Bits | Name     | Value | Description <sup>(1)</sup>                                   |
|------|----------|-------|--------------------------------------------------------------|
| 15-8 | Reserved |       | Any writes to these bit(s) must always have a value of 0.    |
| 7    | INT8     |       | Task 8 Interrupt Overflow Flag Clear                         |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 8 interrupt overflow flag.       |
| 6    | INT7     |       | Task 7 Interrupt Overflow Flag Clear                         |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 7 interrupt overflow flag.       |
| 5    | INT6     |       | Task 6 Interrupt Overflow Flag Clear                         |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 6 interrupt overflow flag.       |
| 4    | INT5     |       | Task 5 Interrupt Overflow Flag Clear                         |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 5 interrupt overflow flag.       |
| 3    | INT4     |       | Task 4 Interrupt Overflow Flag Clear                         |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 4 interrupt overflow flag.       |
| 2    | INT3     |       | Task 3 Interrupt Overflow Flag Clear                         |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 3 interrupt overflow flag.       |
| 1    | INT2     |       | Task 2 Interrupt Overflow Flag Clear                         |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 2 interrupt overflow flag.       |
| 0    | INT1     |       | Task 1 Interrupt Overflow Flag Clear                         |
|      |          | 0     | This bit always reads back 0 and writes of 0 have no effect. |
|      |          | 1     | Write a 1 to clear the task 1 interrupt overflow flag.       |

<sup>(1)</sup> This register is protected by EALLOW and the dual code security module.



### 8.4.4 Execution Registers

The CLA program counter is initialized by the appropriate MVECTx register when an interrupt is received and a task begins execution. The MPC points to the instruction in the decode 2 (D2) stage of the CLA pipeline. After a MSTOP operation, if no other tasks are pending, the MPC will remain pointing to the MSTOP instruction. The MPC register can be read by the main C28x CPU for debug purposes. The main CPU cannot write to MPC.

# 8.4.4.1 MPC Register

The MPC register is described in Figure 8-13 and described in Table 8-13.

### Figure 8-13. Program Counter (MPC)

| 15 |          | 12 | 11 | 0   |  |
|----|----------|----|----|-----|--|
|    | Reserved |    |    | MPC |  |
|    | R-0      |    |    | R-0 |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 8-13. Program Counter (MPC) Field Descriptions

| Bits  | Name     | Value          | Description <sup>(1)</sup>                                                                                                                              |
|-------|----------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Reserved |                | Any writes to these bit(s) must always have a value of 0.                                                                                               |
| 11-0  | MPC      | 0000 -<br>0FFF | Points to the instruction currently in the decode 2 phase of the CLA pipeline. The value is the offset from the first address in the CLA program space. |

(1) This register is protected by the dual code security module. The main CPU can read this register for debug purposes but it can not write to it.

### 8.4.4.2 MSTF Register

The CLA status register (MSTF) reflects the results of different operations. These are the basic rules for the flags:

- Zero and negative flags are cleared or set based on:
  - floating-point moves to registers
  - the result of compare, minimum, maximum, negative and absolute value operations
  - the integer result of operations such as MMOV16, MAND32, MOR32, MXOR32, MCMP32, MASR32, MLSR32
- Overflow and underflow flags are set by floating-point math instructions such as multiply, add, subtract and 1/x. These flags may also be connected to the peripheral interrupt expansion (PIE) block on your device. This can be useful for debugging underflow and overflow conditions within an application.

The MSTF register is shown in Figure 8-14 and described in Table 8-14.

| 31    |              |                  |                                         |           | 24    | 23     |       |     |       |       |       |       | 16    |
|-------|--------------|------------------|-----------------------------------------|-----------|-------|--------|-------|-----|-------|-------|-------|-------|-------|
|       |              | Reserved         |                                         |           |       |        |       |     | R     | PC    |       |       |       |
| R/W-0 |              |                  |                                         |           |       |        |       |     | R/    | W-0   |       |       |       |
| 15    | 12           | 11               | 10                                      | 9         | 8     | 7      | 6     | 5   | 4     | 3     | 2     | 1     | 0     |
|       | RPC          | MEALLOW          | Reserved                                | RND32     | Res   | served | TF    | Res | erved | ZF    | NF    | LUF   | LVF   |
|       | R/W-0        | R/W-0            | R-0                                     | R/W-0     | R     | 2-0    | R/W-0 | R   | -0    | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|       | DAN - DoodAN | rito: D - Dood c | n = v = v = v = v = v = v = v = v = v = | luo oftor | rooot |        |       |     |       |       |       |       |       |

# Figure 8-14. CLA Status Register (MSTF)

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 8-14. CLA Status (MSTF) Register Field Descriptions

| Bits                     | Field    | Value | Description <sup>(1)</sup>                                                                                                                                                                                                                        |
|--------------------------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 24                  | Reserved | 0     | Reserved for future use                                                                                                                                                                                                                           |
| 23 - 12                  | RPC      |       | Return program counter.                                                                                                                                                                                                                           |
|                          |          |       | The RPC is used to save and restore the MPC address by the MCCNDD and MRCNDD operations.                                                                                                                                                          |
| 11                       | MEALLOW  |       | This bit enables and disables CLA write access to EALLOW protected registers. This is independent of the state of the EALLOW bit in the main CPU status register. This status bit can be saved and restored by the MMOV32 STF, mem32 instruction. |
|                          |          | 0     | The CLA cannot write to EALLOW protected registers. This bit is cleared by the CLA instruction, MEDIS.                                                                                                                                            |
|                          |          | 1     | The CLA is allowed to write to EALLOW protected registers. This bit is set by the CLA instruction, MEALLOW.                                                                                                                                       |
| 10                       | Reserved | 0     | Any writes to these bit(s) must always have a value of 0.                                                                                                                                                                                         |
| 9                        | RND32    |       | Round 32-bit Floating-Point Mode                                                                                                                                                                                                                  |
|                          |          |       | Use the MSETFLG and MMOV32 MSTF, mem32 instructions to change the rounding mode.                                                                                                                                                                  |
|                          |          | 0     | If this bit is zero, the MMPYF32, MADDF32 and MSUBF32 instructions will round to zero (truncate).                                                                                                                                                 |
|                          |          | 1     | If this bit is one, the MMPYF32, MADDF32 and MSUBF32 instructions will round to the nearest even value.                                                                                                                                           |
| 8 - 7                    | Reserved | 0     | Reserved for future use                                                                                                                                                                                                                           |
| 6                        | TF       |       | Test Flag                                                                                                                                                                                                                                         |
|                          |          |       | The MTESTTF instruction can modify this flag based on the condition tested. The MSETFLG and MMOV32 MSTF, mem32 instructions can also be used to modify this flag.                                                                                 |
|                          |          | 0     | The condition tested with the MTESTTF instruction is false.                                                                                                                                                                                       |
|                          |          | 1     | The condition tested with the MTESTTF instruction is true.                                                                                                                                                                                        |
| 5 - 4                    | Reserved |       | These two bits may change based on integer results. These flags are not, however, used by the CLA and therefore marked as reserved.                                                                                                               |
| 3                        | ZF       |       | Zero Flag <sup>(2)(3)</sup>                                                                                                                                                                                                                       |
|                          |          |       | • Instructions that modify this flag based on the floating-point value stored in the destination register:                                                                                                                                        |
|                          |          |       | MMOV32, MMOVD32, MABSF32, MNEGF32                                                                                                                                                                                                                 |
|                          |          |       | <ul> <li>Instructions that modify this flag based on the floating-point result of the operation:</li> </ul>                                                                                                                                       |
|                          |          |       | MCMPF32, MMAXF32, and MMINF32                                                                                                                                                                                                                     |
|                          |          |       | <ul> <li>Instructions that modify this flag based on the integer result of the operation:</li> </ul>                                                                                                                                              |
|                          |          |       | MMOV16, MAND32, MOR32, MXOR32, MCMP32, MASR32, MLSR32 and MLSL32                                                                                                                                                                                  |
|                          |          |       | The MSETFLG and MMOV32 MSTF, mem32 instructions can also be used to modify this flag                                                                                                                                                              |
|                          |          | 0     | The value is not zero.                                                                                                                                                                                                                            |
|                          |          | 1     | The value is zero.                                                                                                                                                                                                                                |
| 2                        | NF       |       | Negative Flag <sup>(2)</sup> (3)                                                                                                                                                                                                                  |
|                          |          |       |                                                                                                                                                                                                                                                   |
|                          |          |       | Instructions that modify this flag based on the floating-point value stored in the destination register:                                                                                                                                          |
|                          |          |       | MMOV32, MMOVD32, MABSF32, MNEGF32                                                                                                                                                                                                                 |
|                          |          |       | Instructions that modify this flag based on the floating-point result of the operation:                                                                                                                                                           |
|                          |          |       | MCMPF32, MMAXF32, and MMINF32                                                                                                                                                                                                                     |
|                          |          |       | Instructions that modify this flag based on the integer result of the operation:                                                                                                                                                                  |
|                          |          |       | MMOV16, MAND32, MOR32, MXOR32, MCMP32, MASR32, MLSR32 and MLSL32                                                                                                                                                                                  |
|                          |          |       | The MSETFLG and MMOV32 MSTF, mem32 instructions can also be used to modify this flag.                                                                                                                                                             |
|                          |          | 0     | The value is not negative.                                                                                                                                                                                                                        |
| 9<br>8 - 7<br>6<br>5 - 4 |          | 1     | The value is negative.                                                                                                                                                                                                                            |

<sup>(1)</sup> This register is protected by the dual code security module. The main CPU can read this register for debug purposes but it can not write to it.

A negative zero floating-point value is treated as a positive zero value when configuring the ZF and NF flags.
 A DeNorm floating-point value is treated as a positive zero value when configuring the ZF and NF flags.



| www | .ti.com |
|-----|---------|
|     |         |

| Bits | Field | Value | Description <sup>(1)</sup>                                                                                                          |
|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------|
| 1    | LUF   |       | Latched Underflow Flag                                                                                                              |
|      |       |       | The following instructions will set this flag to 1 if an underflow occurs: MMPYF32, MADDF32, MSUBF32, MMACF32, MEINVF32, MEISQRTF32 |
|      |       |       | The MSETFLG and MMOV32 MSTF, mem32 instructions can also be used to modify this flag.                                               |
|      |       | 0     | An underflow condition has not been latched.                                                                                        |
|      |       | 1     | An underflow condition has been latched.                                                                                            |
| 0    | LVF   |       | Latched Overflow Flag                                                                                                               |
|      |       |       | The following instructions will set this flag to 1 if an overflow occurs: MMPYF32, MADDF32, MSUBF32, MMACF32, MEINVF32, MEISQRTF32  |
|      |       |       | The MSETFLG and MMOV32 MSTF, mem32 instructions can also be used to modify this flag.                                               |
|      |       | 0     | An overflow condition has not been latched.                                                                                         |
|      |       | 1     | An overflow condition has been latched.                                                                                             |



# 8.5 Pipeline

This section describes the CLA pipeline stages and presents cases where pipeline alignment must be considered.

# 8.5.1 Pipeline Overview

The CLA pipeline is very similar to the C28x pipeline. The pipeline has eight stages:

• Fetch 1 (F1)

During the F1 stage the program read address is placed on the CLA program address bus.

• Fetch 2 (F2)

During the F2 stage the instruction is read using the CLA program data bus.

Decode 1 (D1)

During D1 the instruction is decoded.

• Decode 2 (D2)

Generate the data read address. Changes to MAR0 and MAR1 due to post-increment using indirect addressing takes place in the D2 phase. Conditional branch decisions are also made at this stage based on the MSTF register flags.

• Read 1 (R1)

Place the data read address on the CLA data-read address bus. If a memory conflict exists, the R1 stage will be stalled.

• Read 2 (R2)

Read the data value using the CLA data read data bus.

• Execute (EXE)

Execute the operation. Changes to MAR0 and MAR1 due to loading an immediate value or value from memory take place in this stage.

• Write (W)

Place the write address and write data on the CLA write data bus. If a memory conflict exists, the W stage will be stalled.

# 8.5.2 CLA Pipeline Alignment

The majority of the CLA instructions do not require any special pipeline considerations. This section lists the few operations that do require special consideration.

# • Write Followed by Read

In both the C28x and the CLA pipeline the read operation occurs before the write. This means that if a read operation immediately follows a write, then the read will complete first as shown in Table 8-15. In most cases this does not cause a problem since the contents of one memory location does not depend on the state of another. For accesses to peripherals where a write to one location can affect the value in another location the code must wait for the write to complete before issuing the read as shown in Table 8-16.

This behavior is different for the 28x CPU. For the 28x CPU any write followed by read to the same location is protected by what is called write-followed-by-read protection. This protection automatically stalls the pipeline so that the write will complete before the read. In addition some peripheral frames are protected such that a 28x CPU write to one location within the frame will always complete before a read to the frame. The CLA does not have this protection mechanism. Instead the code must wait to perform the read.



Pipeline

Table 8-15. Write Followed by Read - Read Occurs First F2 Instruction F1 D1 D2 R1 R2 Е w I1 MMOV16 @Reg1, MR3 11 I2 MMOV16 MR2, @Reg2 12 11 12 11 12 11 12 11 12 11 12 11 12 11

| Instruction          | F1 | F2 | D1 | D2 | R1 | R2 | Е  | w  |
|----------------------|----|----|----|----|----|----|----|----|
| I1 MMOV16 @Reg1, MR3 | l1 |    |    |    |    |    |    |    |
| 12                   | 12 | 11 |    |    |    |    |    |    |
| 13                   | 13 | 12 | 11 |    |    |    |    |    |
| 14                   | 14 | 13 | 12 | l1 |    |    |    |    |
| I5 MMOV16 MR2, @Reg2 | 15 | 14 | 13 | 12 | l1 |    |    |    |
|                      |    | 15 | 14 | 13 | 12 | l1 |    |    |
|                      |    |    | 15 | 14 | 13 | 12 | 11 |    |
|                      |    |    |    | 15 | 14 | 13 | 12 | 11 |
|                      |    |    |    |    | 15 | 14 | 13 |    |
|                      |    |    |    |    |    | 15 | 14 |    |
|                      |    |    |    |    |    |    | 15 |    |

# Table 8-16. Write Followed by Read - Write Occurs First

# • Delayed Conditional instructions: MBCNDD, MCCNDD and MRCNDD

Referring to Example 8-1, the following applies to delayed conditional instructions:

– **I**1

11 is the last instruction that can effect the CNDF flags for the branch, call or return instruction. The CNDF flags are tested in the D2 phase of the pipeline. That is, a decision is made whether to branch or not when MBCNDD, MCCNDD or MRCNDD is in the D2 phase.

- I2, I3 and I4

The three instructions preceding MBCNDD can change MSTF flags but will have no effect on whether the MBCNDD instruction branches or not. This is because the flag modification will occur after the D2 phase of the branch, call or return instruction. These three instructions must not be a MSTOP, MDEBUGSTOP, MBCNDD, MCCNDD or MRCNDD.

- I5, I6 and I7

The three instructions following a branch, call or return are always executed irrespective of whether the condition is true or not. These instructions must not be MSTOP, MDEBUGSTOP, MBCNDD, MCCNDD or MRCNDD.

For a more detailed description refer to the functional description for MBCNDD, MCCNDD and MRCNDD.



# Example 8-1. Code Fragment For MBCNDD, MCCNDD or MRCNDD

```
<Instruction 1> ; Il Last instruction that can affect flags for
                        the branch, call or return operation
<Instruction 2> ; I2 Cannot be stop, branch, call or return
<Instruction 3> ; I3 Cannot be stop, branch, call or return
<Instruction 4>
                 ; I4 Cannot be stop, branch, call or return
<branch/call/ret> ; MBCNDD, MCCNDD or MRCNDD
                  ; I5-I7: Three instructions after are always
                  ; executed whether the branch/call or return is
                  ; taken or not
<Instruction 5> ; I5 Cannot be stop, branch, call or return
<Instruction 6> \ ; I6 Cannot be stop, branch, call or return
<Instruction 7>
                 ; I7 Cannot be stop, branch, call or return
<Instruction 8>
                ; 18
                ; 19
<Instruction 9>
. . . .
```

### • Stop or Halting a Task: MSTOP and MDEBUGSTOP

The MSTOP and MDEBUGSTOP instructions cannot be placed three instructions before or after a conditional branch, call or return instruction (MBCNDD, MCCNDD or MRCNDD). Refer to Example 8-1. To single-step through a branch/call or return, insert the MDEBUGSTOP at least four instructions back and step from there.

### • Loading MAR0 or MAR1

A load of auxiliary register MAR0 or MAR1 will occur in the EXE phase of the pipeline. Any post increment of MAR0 or MAR1 using indirect addressing will occur in the D2 phase of the pipeline. Referring to Example 8-2, the following applies when loading the auxiliary registers:

– I1 and I2

The two instructions following the load instruction will use the value in MAR0 or MAR1 before the update occurs.

– I3

Loading of an auxiliary register occurs in the EXE phase while updates due to post-increment addressing occur in the D2 phase. Thus I3 cannot use the auxiliary register or there will be a conflict. In the case of a conflict, the update due to address-mode post increment will win and the auxiliary register will not be updated with #\_X.

- 14

Starting with the 4th instruction MAR0 or MAR1 will have the new value.

### Example 8-2. Code Fragment for Loading MAR0 or MAR1

```
; Assume MAR0 is 50 and #_X is 20
MMOVI16 MAR0, #_X ; Load MAR0 with address of X (20)
<Instruction 1> ; I1 Will use the old value of MAR0 (50)
<Instruction 2> ; I2 Will use the old value of MAR0 (50)
<Instruction 3> ; I3 Cannot use MAR0
<Instruction 4> ; I4 Will use the new value of MAR0 (20)
<Instruction 5> ; I5 Will use the new value of MAR0 (20)
....
```

### 8.5.2.1 ADC Early Interrupt to CLA Response

The ADC offers the option to generate an early interrupt pulse when the ADC begins conversion. This option is selected by setting the ADCCTL1[INTPULSEPOS] bit as documented in the Analog-to-Digital Converter section in this manual. If this option is used to start a CLA task then the CLA will be able to read the result as soon as the conversion completes and the ADC result register updates. This just-in-time sampling along with the low interrupt response of the CLA enable faster system response and higher frequency control loops.

The timing for the ADC conversion is shown in the ADC Reference Guide timing diagrams. From a CLA perspective, the pipeline activity is shown in Table 8-17. The 8th instruction is in the R2 phase just in time to read the result register. While the first seven (7) instructions in the task (I1 to I7) will enter the R2 phase of the pipeline too soon to read the conversion, they can be efficiently used for pre-processing calculations needed by the task.

| ADC Activity        | CLA Activity       | F1 | F2 | D1         | D2 | R1 | R2 | Е | W |
|---------------------|--------------------|----|----|------------|----|----|----|---|---|
| Sample              |                    |    |    |            |    |    |    |   |   |
| Sample              |                    |    |    |            |    |    |    |   |   |
|                     |                    |    |    |            |    |    |    |   |   |
| Sample              |                    |    |    |            |    |    |    |   |   |
| Conversion (1)      | Interrupt Received |    |    |            |    |    |    |   |   |
| Conversion (2)      | Task Startup       |    |    |            |    |    |    |   |   |
| Conversion (3)      | Task Startup       |    |    |            |    |    |    |   |   |
| Conversion (4)      | 11                 | 11 |    |            |    |    |    |   |   |
| Conversion (5)      | 12                 | 12 | 11 |            |    |    |    |   |   |
| Conversion (6)      | 13                 | 13 | 12 | <b>I</b> 1 |    |    |    |   |   |
| Conversion (7)      | 14                 | 14 | 13 | 12         | l1 |    |    |   |   |
| Conversion (8)      | 15                 | 15 | 14 | 13         | 12 | 11 |    |   |   |
| Conversion (9)      | 16                 | 16 | 15 | 14         | 13 | 12 | 11 |   |   |
| Conversion (10)     | 17                 | 17 | 16 | 15         | 14 | 13 | 12 |   |   |
| Conversion (11)     | 18 Read ADC RESULT | 18 | 17 | 16         | 15 | 14 | 13 |   |   |
| Conversion (12)     |                    |    | 18 | 17         | 16 | 15 | 14 |   |   |
| Conversion (13)     |                    |    |    | 18         | 17 | 16 | 15 |   |   |
| Conversion Complete |                    |    |    |            | 18 | 17 | 16 |   |   |
| RESULT Latched      |                    |    |    |            |    | 18 | 17 |   |   |
| RESULT Available    |                    |    |    |            |    |    | 18 |   |   |

### Table 8-17. ADC to CLA Early Interrupt Response

# 8.5.3 Parallel Instructions

Parallel instructions are single opcodes that perform two operations in parallel. The following types of parallel instructions are available: math operation in parallel with a move operation, or two math operations in parallel. Both operations complete in a single cycle and there are no special pipeline alignment requirements.

### Example 8-3. Math Operation with Parallel Load



Pipeline

## Example 8-4. Multiply with Parallel Add



## 8.6 Instruction Set

This section describes the assembly language instructions of the control law accelerator. Also described are parallel operations, conditional operations, resource constraints, and addressing modes. The instructions listed here are independent from C28x and C28x+FPU instruction sets.

## 8.6.1 Instruction Descriptions

This section gives detailed information on the instruction set. Each instruction may present the following information:

- Operands
- Opcode
- Description
- Exceptions
- Pipeline
- Examples
- See also

The example INSTRUCTION is shown to familiarize you with the way each instruction is described. The example describes the kind of information you will find in each part of the individual instruction description and where to obtain more information. CLA instructions follow the same format as the C28x; the source operand(s) are always on the right and the destination operand(s) are on the left.

The explanations for the syntax of the operands used in the instruction descriptions for the C28x CLA are given in Table 8-18.

| Symbol    | Description                                                                                                                                                              |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| #16FHi    | 16-bit immediate (hex or float) value that represents the upper 16-bits of an IEEE 32-bit floating-point value.<br>Lower 16-bits of the mantissa are assumed to be zero. |
| #16FHiHex | 16-bit immediate hex value that represents the upper 16-bits of an IEEE 32-bit floating-point value.<br>Lower 16-bits of the mantissa are assumed to be zero.            |
| #16FLoHex | A 16-bit immediate hex value that represents the lower 16-bits of an IEEE 32-bit floating-point value                                                                    |
| #32Fhex   | 32-bit immediate value that represents an IEEE 32-bit floating-point value                                                                                               |
| #32F      | Immediate float value represented in floating-point representation                                                                                                       |
| #0.0      | Immediate zero                                                                                                                                                           |
| #SHIFT    | Immediate value of 1 to 32 used for arithmetic and logical shifts.                                                                                                       |
| addr      | Opcode field indicating the addressing mode                                                                                                                              |
| CNDF      | Condition to test the flags in the MSTF register                                                                                                                         |
| FLAG      | Selected flags from MSTF register (OR) 8 bit mask indicating which floating-point status flags to change                                                                 |
| MAR0      | auxiliary register 0                                                                                                                                                     |
| MAR1      | auxiliary register 1                                                                                                                                                     |
| MARx      | Either MAR0 or MAR1                                                                                                                                                      |
| mem16     | 16-bit memory location accessed using direct or indirect addressing modes                                                                                                |
| mem32     | 32-bit memory location accessed using direct or indirect addressing modes                                                                                                |
| MRa       | MR0 to MR3 registers                                                                                                                                                     |
| MRb       | MR0 to MR3 registers                                                                                                                                                     |
| MRc       | MR0 to MR3 registers                                                                                                                                                     |
| MRd       | MR0 to MR3 registers                                                                                                                                                     |
| MRe       | MR0 to MR3 registers                                                                                                                                                     |
| MRf       | MR0 to MR3 registers                                                                                                                                                     |
| MSTF      | CLA Floating-point Status Register                                                                                                                                       |
| shift     | Opcode field indicating the number of bits to shift.                                                                                                                     |
| VALUE     | Flag value of 0 or 1 for selected flag (OR) 8 bit mask indicating the flag value; 0 or 1                                                                                 |

#### Table 8-18. Operand Nomenclature



Each instruction has a table that gives a list of the operands and a short description. Instructions always have their destination operand(s) first followed by the source operand(s).

|              | Description                                                                                                                                                                                                                                                                          |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest1        | Description for the 1st operand for the instruction                                                                                                                                                                                                                                  |
| source1      | Description for the 2nd operand for the instruction                                                                                                                                                                                                                                  |
| source2      | Description for the 3rd operand for the instruction                                                                                                                                                                                                                                  |
| Opcode       | This section shows the opcode for the instruction                                                                                                                                                                                                                                    |
| Description  | Detailed description of the instruction execution is described. Any constraints on the operands imposed by the processor or the assembler are discussed.                                                                                                                             |
| Restrictions | Any constraints on the operands or use of the instruction imposed by the processor are discussed.                                                                                                                                                                                    |
| Pipeline     | This section describes the instruction in terms of pipeline cycles as described in Section 8.5                                                                                                                                                                                       |
| Example      | Examples of instruction execution. If applicable, register and memory values are given before and after instruction execution. Some examples are code fragments while other examples are full tasks that assume the CLA is correctly configured and the main CPU has passed it data. |
| Operands     | Each instruction has a table that gives a list of the operands and a short description. Instructions always have their destination operand(s) first followed by the source operand(s).                                                                                               |

# Table 8-19. INSTRUCTION dest, source1, source2 Short Description



## 8.6.2 Addressing Modes and Encoding

The CLA uses the same address to access data and registers as the main CPU. For example if the main CPU accesses an ePWM register at address 0x00 6800, then the CLA will access it using address 0x6800. Since all CLA accessible memory and registers are within the low 64k x 16 of memory, only the low 16-bits of the address are used by the CLA.

To address the CLA data memory, message RAMs and shared peripherals, the CLA supports two addressing modes:

- Direct addressing mode: Uses the address of the variable or register directly.
- Indirect addressing with 16-bit post increment. This mode uses either XAR0 or XAR1.

The CLA does not use a data page pointer or a stack pointer. The two addressing modes are encoded as shown Table 8-20.

| Addressing Mode | 'addr' Opcode<br>Field<br>Encode <sup>(1)</sup> | Description                                                                                                                                                                                                                  |  |  |  |
|-----------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| @dir            | 0000                                            | Direct Addressing Mode                                                                                                                                                                                                       |  |  |  |
|                 |                                                 | Example 1: MMOV32 MR1, @_VarA                                                                                                                                                                                                |  |  |  |
|                 |                                                 | Example 2: MMOV32 MR1, @_EPwm1Regs.CMPA.all                                                                                                                                                                                  |  |  |  |
|                 |                                                 | In this case the 'mmmm mmmm mmmm' opcode field will be populated with the 16-bit address of the variable. This is the low 16-bits of the address that you would use to access the variable using the main CPU.               |  |  |  |
|                 |                                                 | For example @_VarA will populate the address of the variable VarA. and @_EPwm1Regs.CMPA.all will populate the address of the CMPA register.                                                                                  |  |  |  |
| *MAR0[#imm16]++ | 0001                                            | MAR0 Indirect Addressing with 16-bit Immediate Post Increment                                                                                                                                                                |  |  |  |
| *MAR1[#imm16]++ | 0010                                            | MAR1 Indirect Addressing with 16-bit Immediate Post Increment                                                                                                                                                                |  |  |  |
|                 |                                                 | addr = MAR0 (or MAR1) Access memory using the address stored in MAR0 (or MAR1)<br>MAR0 (or MAR1) += Then post increment MAR0 (or MAR1) by #imm16.<br>#imm16                                                                  |  |  |  |
|                 |                                                 | Example 1: MMOV32 MR0, *MAR0[2]++                                                                                                                                                                                            |  |  |  |
|                 |                                                 | Example 2: MMOV32 MR1, *MAR1[-2]++                                                                                                                                                                                           |  |  |  |
|                 |                                                 | For a post increment of 0 the assembler will accept both *MAR0 and *MAR0[0]++.                                                                                                                                               |  |  |  |
|                 |                                                 | The 'mmmm mmmm mmmm' opcode field will be populated with the signed 16-bit pointer offset. For example if #imm16 is 2, then the opcode field will be 0x0002. Likewise if #imm16 is -2, then the opcode field will be 0xFFFE. |  |  |  |
|                 |                                                 | If addition of the 16-bit immediate causes overflow, then the value will wrap around on a 16-bit boundary.                                                                                                                   |  |  |  |

### Table 8-20. Addressing Modes

<sup>(1)</sup> Values not shown are reserved.

Encoding for the shift fields in the MASR32, MLSR32 and MLSL32 instructions is shown in Table 8-21

#### Table 8-21. Shift Field Encoding

| Shift Value | 'shift' Opcode<br>Field Encode |  |
|-------------|--------------------------------|--|
| 1           | 0000                           |  |
| 2           | 0001                           |  |
| 3           | 0010                           |  |
|             |                                |  |
| 32          | 1111                           |  |

Table 8-22 shows the condition field encoding for conditional instructions such as MNEGF, MSWAPF, MBCNDD, MCCNDD and MRCNDD

# TEXAS INSTRUMENTS

#### www.ti.com

Instruction Set

| Table 8-22. Condition Field Encoding |                     |                                      |                     |  |  |  |
|--------------------------------------|---------------------|--------------------------------------|---------------------|--|--|--|
| Encode <sup>(1)</sup>                | CNDF                | Description                          | MSTF Flags Tested   |  |  |  |
| 0000                                 | NEQ                 | Not equal to zero                    | ZF == 0             |  |  |  |
| 0001                                 | EQ                  | Equal to zero                        | ZF == 1             |  |  |  |
| 0010                                 | GT                  | Greater than zero                    | ZF == 0 AND NF == 0 |  |  |  |
| 0011                                 | GEQ                 | Greater than or equal to zero        | NF == 0             |  |  |  |
| 0100                                 | LT                  | Less than zero                       | NF == 1             |  |  |  |
| 0101                                 | LEQ                 | Less than or equal to zero           | ZF == 1 OR NF == 1  |  |  |  |
| 1010                                 | TF                  | Test flag set                        | TF == 1             |  |  |  |
| 1011                                 | NTF                 | Test flag not set                    | TF == 0             |  |  |  |
| 1100                                 | LU                  | Latched underflow                    | LUF == 1            |  |  |  |
| 1101                                 | LV                  | Latched overflow                     | LVF == 1            |  |  |  |
| 1110                                 | UNC                 | Unconditional                        | None                |  |  |  |
| 1111                                 | UNCF <sup>(2)</sup> | Unconditional with flag modification | None                |  |  |  |

(1) Values not shown are reserved.

<sup>(2)</sup> This is the default operation if no CNDF field is specified. This condition will allow the ZF and NF flags to be modified when a conditional operation is executed. All other conditions will not modify these flags.

# 8.6.3 Instructions

The instructions are listed alphabetically, preceded by a summary. Table 8-23. General Instructions

## Title

www.ti.com

| MMABSF32 MRa, MRb — 32-Bit Floating-Point Absolute Value                                           |     |
|----------------------------------------------------------------------------------------------------|-----|
| MADD32 MRa, MRb, MRc — 32-Bit Integer Add                                                          |     |
| MADDF32 MRa, #16FHi, MRb — 32-Bit Floating-Point Addition                                          |     |
| MADDF32 MRa, MRb, #16FHi — 32-Bit Floating-Point Addition                                          |     |
| MADDF32 MRa, MRb, MRc — 32-Bit Floating-Point Addition                                             |     |
| MADDF32 MRd, MRe, MRf  MMOV32 mem32, MRa — 32-Bit Floating-Point Addition with Parallel Move       | 554 |
| MADDF32 MRd, MRe, MRf   MMOV32 MRa, mem32 — 32-Bit Floating-Point Addition with Parallel Move      |     |
| MAND32 MRa, MRb, MRc — Bitwise AND                                                                 |     |
| MASR32 MRa, #SHIFT — Arithmetic Shift Right                                                        | 558 |
| MBCNDD 16BitDest {, CNDF} — Branch Conditional Delayed                                             | 559 |
| MCCNDD 16BitDest {, CNDF} — Call Conditional Delayed                                               | 564 |
| MCMP32 MRa, MRb — 32-Bit Integer Compare for Equal, Less Than or Greater Than                      | 568 |
| MCMPF32 MRa, MRb — 32-Bit Floating-Point Compare for Equal, Less Than or Greater Than              | 569 |
| MCMPF32 MRa, #16FHi — 32-Bit Floating-Point Compare for Equal, Less Than or Greater Than           |     |
| MDEBUGSTOP — Debug Stop Task                                                                       | 572 |
| MEALLOW — Enable CLA Write Access to EALLOW Protected Registers                                    | 573 |
| MEDIS — Disable CLA Write Access to EALLOW Protected Registers                                     | 574 |
| MEINVF32 MRa, MRb — 32-Bit Floating-Point Reciprocal Approximation                                 | 575 |
| MEISQRTF32 MRa, MRb — 32-Bit Floating-Point Square-Root Reciprocal Approximation                   | 576 |
| MF32TOI16 MRa, MRb — Convert 32-Bit Floating-Point Value to 16-Bit Integer                         |     |
| MF32TOI16R MRa, MRb — Convert 32-Bit Floating-Point Value to 16-Bit Integer and Round              | 578 |
| MF32TOI32 MRa, MRb — Convert 32-Bit Floating-Point Value to 32-Bit Integer                         | 579 |
| MF32TOUI16 MRa, MRb — Convert 32-Bit Floating-Point Value to 16-bit Unsigned Integer               | 580 |
| MF32TOUI16R MRa, MRb — Convert 32-Bit Floating-Point Value to 16-bit Unsigned Integer and Round    | 581 |
| MF32TOUI32 MRa, MRb — Convert 32-Bit Floating-Point Value to 32-Bit Unsigned Integer               | 582 |
| MFRACF32 MRa, MRb — Fractional Portion of a 32-Bit Floating-Point Value                            | 583 |
| MI16TOF32 MRa, MRb — Convert 16-Bit Integer to 32-Bit Floating-Point Value                         | 584 |
| MI16TOF32 MRa, mem16 — Convert 16-Bit Integer to 32-Bit Floating-Point Value                       |     |
| MI32TOF32 MRa, mem32 — Convert 32-Bit Integer to 32-Bit Floating-Point Value                       | 586 |
| MI32TOF32 MRa, MRb — Convert 32-Bit Integer to 32-Bit Floating-Point Value                         |     |
| MLSL32 MRa, #SHIFT — Logical Shift Left                                                            | 588 |
| MLSR32 MRa, #SHIFT — Logical Shift Right                                                           | 589 |
| MMACF32 MR3, MR2, MRd, MRe, MRf   MMOV32 MRa, mem32 -32-Bit Floating-Point Multiply and Accumulate |     |
| with Parallel Move                                                                                 | 590 |
| MMAXF32 MRa, MRb — 32-Bit Floating-Point Maximum                                                   | 593 |
| MMAXF32 MRa, #16FHi — 32-Bit Floating-Point Maximum                                                | 595 |
| MMINF32 MRa, MRb — 32-Bit Floating-Point Minimum                                                   | 596 |
| MMINF32 MRa, #16FHi — 32-Bit Floating-Point Minimum                                                | 598 |
| MMOV16 MARx, MRa, #16I — Load the Auxiliary Register with MRa + 16-bit Immediate Value             | 599 |
| MMOV16 MARx, mem16 — Load MAR1 with 16-bit Value                                                   | 601 |
| MMOV16 mem16, MARx — Move 16-Bit Auxiliary Register Contents to Memory                             | 603 |
| MMOV16 mem16, MRa — Move 16-Bit Floating-Point Register Contents to Memory                         | 604 |
| MMOV32 mem32, MRa — Move 32-Bit Floating-Point Register Contents to Memory                         | 605 |
| MMOV32 mem32, MSTF — Move 32-Bit MSTF Register to Memory                                           | 606 |
| MMOV32 MRa, mem32 {, CNDF} — Conditional 32-Bit Move                                               | 607 |
| MMOV32 MRa, MRb {, CNDF} — Conditional 32-Bit Move                                                 | 609 |
|                                                                                                    |     |



# Table 8-23. General Instructions (continued)

| MMOV32 MSTF, mem32 — Move 32-Bit Value from Memory to the MSTF Register                               | 611 |
|-------------------------------------------------------------------------------------------------------|-----|
| MMOVD32 MRa, mem32 — Move 32-Bit Value from Memory with Data Copy                                     | 612 |
| MMOVF32 MRa, #32F — Load the 32-Bits of a 32-Bit Floating-Point Register                              | 613 |
| MMOVI16 MARx, #16I — Load the Auxiliary Register with the 16-Bit Immediate Value                      | 614 |
| MMOVI32 MRa, #32FHex — Load the 32-Bits of a 32-Bit Floating-Point Register with the Immediate        | 615 |
| MMOVIZ MRa, #16FHi — Load the Upper 16-Bits of a 32-Bit Floating-Point Register                       | 616 |
| MMOVZ16 MRa, mem16 — Load MRx With 16-bit Value                                                       | 617 |
| MMOVXI MRa, #16FLoHex — Move Immediate to the Low 16-Bits of a Floating-Point Register                | 618 |
| MMPYF32 MRa, MRb, MRc — 32-Bit Floating-Point Multiply                                                | 619 |
| MMPYF32 MRa, #16FHi, MRb — 32-Bit Floating-Point Multiply                                             | 620 |
| MMPYF32 MRa, MRb, #16FHi — 32-Bit Floating-Point Multiply                                             | 622 |
| MMPYF32 MRa, MRb, MRc  MADDF32 MRd, MRe, MRf — 32-Bit Floating-Point Multiply with Parallel Add       | 624 |
| MMPYF32 MRd, MRe, MRf   MMOV32 MRa, mem32 — 32-Bit Floating-Point Multiply with Parallel Move         | 626 |
| MMPYF32 MRd, MRe, MRf   MMOV32 mem32, MRa — 32-Bit Floating-Point Multiply with Parallel Move         | 628 |
| MMPYF32 MRa, MRb, MRc   MSUBF32 MRd, MRe, MRf - 32-Bit Floating-Point Multiply with Parallel Subtract | 629 |
| MNEGF32 MRa, MRb{, CNDF} — Conditional Negation                                                       | 630 |
| MNOP — No Operation                                                                                   | 632 |
| MOR32 MRa, MRb, MRc — Bitwise OR                                                                      | 633 |
| MRCNDD {CNDF} — Return Conditional Delayed                                                            | 634 |
| MSETFLG FLAG, VALUE — Set or Clear Selected Floating-Point Status Flags                               | 638 |
| MSTOP — Stop Task                                                                                     | 639 |
| MSUB32 MRa, MRb, MRc — 32-Bit Integer Subtraction                                                     | 641 |
| MSUBF32 MRa, MRb, MRc — 32-Bit Floating-Point Subtraction                                             | 642 |
| MSUBF32 MRa, #16FHi, MRb — 32-Bit Floating-Point Subtraction                                          | 643 |
| MSUBF32 MRd, MRe, MRf   MMOV32 MRa, mem32 — 32-Bit Floating-Point Subtraction with Parallel Move      | 644 |
| MSUBF32 MRd, MRe, MRf   MMOV32 mem32, MRa - 32-Bit Floating-Point Subtraction with Parallel Move      | 645 |
| MSWAPF MRa, MRb {, CNDF} — Conditional Swap                                                           | 646 |
| MMTESTTF CNDF — Test MSTF Register Flag Condition                                                     | 648 |
| MUI16TOF32 MRa, mem16 — Convert Unsigned 16-Bit Integer to 32-Bit Floating-Point Value                | 650 |
| MUI16TOF32 MRa, MRb — Convert Unsigned 16-Bit Integer to 32-Bit Floating-Point Value                  | 651 |
| MUI32TOF32 MRa, mem32 — Convert Unsigned 32-Bit Integer to 32-Bit Floating-Point Value                | 652 |
| MUI32TOF32 MRa, MRb — Convert Unsigned 32-Bit Integer to 32-Bit Floating-Point Value                  | 653 |
| MXOR32 MRa, MRb, MRc — Bitwise Exclusive Or                                                           | 654 |
|                                                                                                       |     |



## MMABSF32 MRa, MRb 32-Bit Floating-Point Absolute Value

| MRaCLA floating-point destination register (MR0 to MR3)MRbCLA floating-point source register (MR0 to MR3)OpcodeLSW: 0000 0000 0000 bbaa<br>MSW: 0111 1110 0010 0000DescriptionThe absolute value of MRb is loaded into MRa. Only the sign bit of the operand is<br>modified by the MMABSF32 instruction.<br>if (MRb < 0) {NRa = -MRb};<br>else {MRa = MRb};FlagsThis instruction modifies the following flags in the MSTF register:<br>Flag TF ZF NF LUF LVF<br>Modified No Yes Yes No NoPipelineThis instruction modifies are modified as follows:<br>NF = 0;<br>ZF = 0;<br>if (MRa(30:23) == 0) ZF = 1;PipelineThis is a single-cycle instruction.ExampleMMOVIZ MR0, #-2.0 ; MR0 = -2.0 (0xC000000)<br>MMABSF32 MR0, MR0 ; MR0 = 2.0 (0x4000000), ZF = NF = 0MMOVIZ MR0, #5.0 ; ME0 = 5.0 (0x40A00000)<br>MMABSF32 MR0, MR0 ; MR0 = 0.0 ZF = 1, NF = 0MMOVIZ MR0, #0, 0 ; MR0 = 0.0<br>MMOVIZ MR0, #0, 0 ; MR0 = 0.0<br>MMADSF32 MR0, MR0 ; MR0 = 0.0 ZF = 1, NF = 0See alsoMNEGF32 MRa, MRb {, CNDF} | oporariao   |                    |                                                          |                     |                       |                     |                |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|----------------------------------------------------------|---------------------|-----------------------|---------------------|----------------|--|--|--|
| OpcodeLSW: 0000 0000 0000 bbaa<br>MSW: 0111 1110 0010 0000DescriptionThe absolute value of MRb is loaded into MRa. Only the sign bit of the operand is<br>modified by the MMABSF32 instruction.<br>if (MRb < 0) {MRa = -MRb};                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             | MRa                | MRa CLA floating-point destination register (MR0 to MR3) |                     |                       |                     |                |  |  |  |
| OpcodeLSW: 0000 0000 0000 bbaa<br>MSW: 0111 1110 0010 0000DescriptionThe absolute value of MRb is loaded into MRa. Only the sign bit of the operand is<br>modified by the MMABSF32 instruction.<br>if (MRb < 0) {MRa = -MRb};<br>else {MRa = MRb};FlagsThis instruction modifies the following flags in the MSTF register:FlagsThis instruction modifies are modified as follows:<br>NoNF = 0;<br>if (MRa(30:23) == 0) ZF = 1;NFLUFPipelineThis is a single-cycle instruction.ExampleMMOVIZ MRO, #-2.0 ; MRO = -2.0 (0xC000000)<br>MMABSF32 MRO, MRO ; MRO = 5.0 (0x40A00000), ZF = NF = 0<br>MMOVIZ MRO, #5.0 ; MRO = 5.0 (0x40A00000), ZF = NF = 0<br>MMOVIZ MRO, #0.0 ; MRO = 0.0 MMOVIZ MRO, #0.0 ; MRO = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                        |             | MRb                | CL                                                       | A floating-point so | urce register (MR0 to | o MR3)              |                |  |  |  |
| $MSW: 0111 1110 0010 0000$ Description The absolute value of MRb is loaded into MRa. Only the sign bit of the operand is modified by the MMABSF32 instruction. if (MRb < 0) {MRa = -MRb}; else {MRa = MRb}; Flags This instruction modifies the following flags in the MSTF register: $\frac{Flag}{MRa} = \frac{TF}{RB} = \frac{ZF}{RF} = \frac{NF}{RF} = \frac{LUF}{RF} = \frac{LVF}{R}$ Modified No Yes Yes No No The MSTF register flags are modified as follows: $NF = 0;$ $ZF = 0;$ if (MRa(30:23) == 0) ZF = 1; Pipeline This is a single-cycle instruction. Example MMOVIZ MRO, #-2.0 ; MRO = -2.0 (0xC000000) MMABSF32 MRO, MRO ; MRO = 5.0 (0x40A00000), ZF = NF = 0 MMOVIZ MRO, #5.0 ; MRO = 5.0 (0x40A00000), ZF = NF = 0 MMOVIZ MRO, #0.0 ; MRO = 0.0 MMABSF32 MRO, MRO ; MRO = 0.0 ZF = 1, NF = 0                                                                                                                                                                                          |             |                    |                                                          | 01                  | <b>U</b> (            | ,                   |                |  |  |  |
| DescriptionThe absolute value of MRb is loaded into MRa. Only the sign bit of the operand is modified by the MMABSF32 instruction.if (MRb < 0) {MRa = -MRb};<br>else {MRa = MRb};This instruction modifies the following flags in the MSTF register:FlagsThis instruction modifies the following flags in the MSTF register:FlagTFZFNFLUFLVFModifiedNoYesYesNoThe MSTF register flags are modified as follows:NF = 0;<br>ZF = 0;<br>if ( MRa(30:23) == 0) ZF = 1;PipelineThis is a single-cycle instruction.ExampleMMOVIZ MR0, #-2.0 ; MR0 = -2.0 (0xC000000)<br>MMABSF32 MR0, MRO ; MRO = 2.0 (0x40A00000), ZF = NF = 0MMOVIZ MR0, #5.0 ; MR0 = 5.0 (0x40A00000)<br>MMABSF32 MR0, MRO ; MRO = 5.0 (0x40A00000), ZF = NF = 0MMOVIZ MR0, #0.0 ; MR0 = 0.0<br>MMABSF32 MRO, MRO ; MRO = 0.0<br>ZF = 1, NF = 0                                                         | Opcode      | LSW: 0000          | 0000 0000                                                | bbaa                |                       |                     |                |  |  |  |
| modified by the MMABSF32 instruction.if (MRb < 0) {MRa = -MRb};<br>else {MRa = MRb};FlagsThis instruction modifies the following flags in the MSTF register:FlagTFZFNFLUFLVFModifiedNoYesYesNoNoThe MSTF register flags are modified as follows:NF = 0;<br>ZF = 0;<br>if (MRa(30:23) == 0) ZF = 1;PipelineThis is a single-cycle instruction.ExampleMMOVIZ MR0, #-2.0; MR0 = -2.0 (0xC000000)<br>MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x4000000), ZF = NF = 0MMOVIZ MR0, #5.0; MR0 = 5.0 (0x4000000)<br>MMABSF32 MR0, MR0 ; MR0 = 0.0 ZF = 1, NF = 0MMOVIZ MR0, #0.0; MR0 = 0.0<br>MMABSF32 MR0, MR0 ; MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                                                                               |             | MSW: 0111          | 1110 0010                                                | 0000                |                       |                     |                |  |  |  |
| $else \{MRa = MRb\};$ Flags This instruction modifies the following flags in the MSTF register: $\frac{Flag TF ZF NF LUF LVF}{Modified No Yes Yes No No}$ The MSTF register flags are modified as follows: $NF = 0;$ $ZF = 0;$ if (MRa(30:23) == 0) ZF = 1; Pipeline This is a single-cycle instruction. Example MMOVIZ MR0, #-2.0; MR0 = -2.0 (0xC000000) MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x4000000), ZF = NF = 0 MMOVIZ MR0, #0.0 ; MR0 = 0.0 MMOVIZ MR0, #0.0 ; MR0 = 0.0 MMOVIZ MR0, #0.0 ; MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Description |                    |                                                          |                     |                       | y the sign bit of t | the operand is |  |  |  |
| FlagTFZFNFLUFLVFModifiedNoYesYesNoNoThe MSTF register flags are modified as follows:NF = 0;<br>ZF = 0;<br>if ( MRa(30:23) == 0) ZF = 1;PipelineThis is a single-cycle instruction.ExampleMMOVIZ MR0, #-2.0 ; MR0 = -2.0 (0xC000000)<br>MMABSF32 MR0, MR0 ; MR0 = 2.0 (0x4000000), ZF = NF = 0MMOVIZ MR0, #5.0 ; MR0 = 5.0 (0x40A00000)<br>MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x40A00000), ZF = NF = 0MMOVIZ MR0, #0.0 ; MR0 = 0.0<br>MMOVIZ MR0, #0.0 ; MR0 = 0.0<br>MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |             |                    |                                                          | ,                   |                       |                     |                |  |  |  |
| Modified         No         Yes         Yes         No         No           The MSTF register flags are modified as follows:         NF = 0;<br>ZF = 0;<br>if ( MRa(30:23) == 0) ZF = 1;         NF = 0;<br>MRa(30:23) == 0) ZF = 1;         This is a single-cycle instruction.           Pipeline         This is a single-cycle instruction.         MMOVIZ MR0, #-2.0 ; MR0 = -2.0 (0xC000000)<br>MMABSF32 MR0, MR0 ; MR0 = 2.0 (0x4000000), ZF = NF = 0         MMOVIZ MR0, #5.0 ; MR0 = 5.0 (0x40A00000)<br>MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x40A00000), ZF = NF = 0           MMOVIZ MR0, #0.0 ; MR0 = 0.0 ZF = 1, NF = 0         MMOVIZ MR0, #0.0 ; MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                     | Flags       | This instru        | ction modi                                               | fies the followi    | ng flags in the M     | STF register:       |                |  |  |  |
| The MSTF register flags are modified as follows:         NF = 0;         ZF = 0;         if (MRa(30:23) == 0) ZF = 1;         Pipeline         This is a single-cycle instruction.         Example         MMOVIZ MR0, #-2.0 ; MR0 = -2.0 (0xC000000)<br>MMABSF32 MR0, MR0 ; MR0 = 2.0 (0x4000000), ZF = NF = 0         MMOVIZ MR0, #5.0 ; MR0 = 5.0 (0x40A0000)<br>MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x40A0000), ZF = NF = 0         MMOVIZ MR0, #0.0 ; MR0 = 0.0 [MMOVIZ MR0, #0.0 ; MR0 = 0.0 ]         MMOVIZ MR0, #0.0 ; MR0 = 0.0 [MMABSF32 MR0, MR0 ; MR0 = 0.0 ]                                                                                                                                                                                                                                                                                                                                                                                                                                   |             | Flag               | TF                                                       | ZF                  | NF                    | LUF                 | LVF            |  |  |  |
| NF = 0;         ZF = 0;         if (MRa(30:23) == 0) ZF = 1;         Pipeline         This is a single-cycle instruction.         Example         MMOVIZ MR0, #-2.0 ; MR0 = -2.0 (0xC000000)<br>MMABSF32 MR0, MR0 ; MR0 = 2.0 (0x4000000), ZF = NF = 0         MMOVIZ MR0, #5.0 ; MR0 = 5.0 (0x40A00000)<br>MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x40A00000), ZF = NF = 0         MMOVIZ MR0, #0.0 ; MR0 = 0.0 (0x40A00000), ZF = NF = 0         MMOVIZ MR0, #0.0 ; MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |             | Modified           | No                                                       | Yes                 | Yes                   | No                  | No             |  |  |  |
| Example       MMOVIZ MR0, #-2.0 ; MR0 = -2.0 (0xC000000)<br>MMABSF32 MR0, MR0 ; MR0 = 2.0 (0x4000000), ZF = NF = 0         MMOVIZ MR0, #5.0 ; MR0 = 5.0 (0x40A00000)<br>MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x40A00000), ZF = NF = 0         MMOVIZ MR0, #0.0 ; MR0 = 0.0<br>MMOVIZ MR0, #0.0 ; MR0 = 0.0<br>MMABSF32 MR0, MR0 ; MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             | NF = 0;<br>ZF = 0; | -                                                        | -                   | ed as follows:        |                     |                |  |  |  |
| MMABSF32 MR0, MR0 ; MR0 = 2.0 (0x40000000), ZF = NF = 0<br>MMOVIZ MR0, #5.0 ; MR0 = 5.0 (0x40A00000)<br>MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x40A00000), ZF = NF = 0<br>MMOVIZ MR0, #0.0 ; MR0 = 0.0<br>MMABSF32 MR0, MR0 ; MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Pipeline    | This is a si       | ngle-cycle                                               | instruction.        |                       |                     |                |  |  |  |
| MMABSF32 MR0, MR0 ; MR0 = 5.0 (0x40A00000), ZF = NF = 0<br>MMOVIZ MR0, #0.0 ; MR0 = 0.0<br>MMABSF32 MR0, MR0 ; MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Example     |                    |                                                          |                     |                       |                     |                |  |  |  |
| MMABSF32 MR0, MR0 ; MR0 = 0.0 ZF = 1, NF = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |             |                    |                                                          |                     |                       |                     |                |  |  |  |
| See also MNEGF32 MRa, MRb {, CNDF}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |                    |                                                          |                     | F = 1, NF = 0         |                     |                |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | See also    | MNEGF32            | MRa, MR                                                  | b {, CNDF}          |                       |                     |                |  |  |  |

# MADD32 MRa, MRb, MRc 32-Bit Integer Add

| Operands    |                                                                                                                                              |                                                                                                      |                                |                         |             |     |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------|-------------------------|-------------|-----|--|--|--|--|
|             | MRa                                                                                                                                          | CL                                                                                                   | A floating-point de            | stination register (M   | IR0 to MR3) |     |  |  |  |  |
|             | MRb                                                                                                                                          | MRb CLA floating-point destination register (MR0 to MR3)                                             |                                |                         |             |     |  |  |  |  |
|             | MRc                                                                                                                                          | CL                                                                                                   | A floating-point de            | stination register (M   | IR0 to MR3) |     |  |  |  |  |
| Opcode      | LSW: 0000 000cc bbaa<br>MSW: 0111 1110 1100 0000                                                                                             |                                                                                                      |                                |                         |             |     |  |  |  |  |
| Description |                                                                                                                                              | •                                                                                                    | n of MRb and N                 |                         |             |     |  |  |  |  |
|             |                                                                                                                                              |                                                                                                      | 0) + MRc(31:0)                 |                         |             |     |  |  |  |  |
| Flags       | -                                                                                                                                            | uction modi                                                                                          | fies the followir<br>ZF        | ng flags in the M<br>NF | -           | LVF |  |  |  |  |
|             | Flag<br>Modified                                                                                                                             | No                                                                                                   | Yes                            | Yes                     | LUF<br>No   | No  |  |  |  |  |
|             | NF = MRa(<br>ZF = 0;                                                                                                                         | The MSTF register flags are modified based on the integer results of the operation.<br>NF = MRa(31); |                                |                         |             |     |  |  |  |  |
| Pipeline    |                                                                                                                                              |                                                                                                      | $\{ ZF = 1; \};$               |                         |             |     |  |  |  |  |
| Example     | <pre>This is a single-cycle instruction.  ; Given A = (int32)1 ; B = (int32)2 ; C = (int32)-7 ; ; Calculate Y2 = A + B + C ;ClalTask1:</pre> |                                                                                                      |                                |                         |             |     |  |  |  |  |
| See also    | MASR32<br>MLSL32 M<br>MLSR32 M<br>MOR32 M<br>MXOR32                                                                                          | MRa, MRb<br>MRa, #SHI<br>MRa, #SHIF<br>MRa, #SHI<br>IRa, MRb,<br>MRa, MRb<br>MRa, MRb                | FT<br>FT<br>FT<br>MRc<br>, MRc |                         |             |     |  |  |  |  |



# MADDF32 MRa, #16FHi, MRb 32-Bit Floating-Point Addition

| Operands    |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                            |                                                  |                 |                                      |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--------------------------------------------------|-----------------|--------------------------------------|--|--|
|             | MRa                                                                                                                                | CL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A floating-point de                        | stination register (MF                           | R0 to MR3)      |                                      |  |  |
|             | #16FHi                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                            | alue that represents t<br>16-bits of the mantise |                 | an IEEE 32-bit floating-<br>e all 0. |  |  |
|             | MRb                                                                                                                                | CL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A floating-point so                        | urce register (MR0 to                            | o MR3)          |                                      |  |  |
| Opcode      | LSW: IIII<br>MSW: 0111                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                            |                                                  |                 |                                      |  |  |
| Description | Add MRb to<br>result of the                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | • •                                        | represented by                                   | the immediate o | perand. Store the                    |  |  |
|             | floating-poi<br>most usefu<br>Some exar<br>(0xBFC000<br>That is, the<br>MRa = MRb                                                  | <pre>#16FHi is a 16-bit immediate value that represents the upper 16-bits of an IEEE 32-bit<br/>floating-point value. The low 16-bits of the mantissa are assumed to be all 0. #16FHi is<br/>most useful for representing constants where the lowest 16-bits of the mantissa are 0.<br/>Some examples are 2.0 (0x4000000), 4.0 (0x40800000), 0.5 (0x3F000000), and -1.5<br/>(0xBFC00000). The assembler will accept either a hex or float as the immediate value.<br/>That is, the value -1.5 can be represented as #-1.5 or #0xBFC0.<br/>MRa = MRb + #16FHi:0;<br/>This instruction can also be written as MADDF32 MRa, MRb, #16FHi.</pre> |                                            |                                                  |                 |                                      |  |  |
| Flags       | This instrue                                                                                                                       | ction modi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ifies the followir                         | ng flags in the M                                | STF register:   |                                      |  |  |
|             | Flag                                                                                                                               | TF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ZF                                         | NF                                               | LUF             | LVF                                  |  |  |
|             | Modified                                                                                                                           | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | No                                         | No                                               | Yes             | Yes                                  |  |  |
|             | The MSTF                                                                                                                           | register f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | lags are modifie                           | ed as follows:                                   |                 |                                      |  |  |
|             | <ul> <li>The MSTF register flags are modified as follows:</li> <li>LUF = 1 if MADDF32 generates an underflow condition.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                            |                                                  |                 |                                      |  |  |
|             |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | -                                          | an overflow con                                  |                 |                                      |  |  |
| Pipeline    |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | e instruction.                             |                                                  |                 |                                      |  |  |
| Example     | ; Add to MR1 the value 2.0 in 32-bit floating-point format                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                            |                                                  |                 |                                      |  |  |
|             | ; Store the result in MRO                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                            |                                                  |                 |                                      |  |  |
|             | MADDF32 MR0, #2.0, MR1 ; MR0 = 2.0 + MR1                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                            |                                                  |                 |                                      |  |  |
|             |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                            | -bit floating-p                                  | oint format     |                                      |  |  |
|             | ; Store th<br>MADDF32                                                                                                              | e result<br>MR2, #-2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                            | = -2.5 + MR3                                     |                 |                                      |  |  |
|             | ; Store th                                                                                                                         | e result                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | lue 0x3FC00000<br>in MR3<br>FC0, MR3 ; MR3 |                                                  |                 |                                      |  |  |
| See also    | MADDF32                                                                                                                            | MRa, MR<br>MRd, MR<br>MRd, MR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | b, MRc<br>e, MRf    MMO<br>e, MRf    MMO   | V32 MRa, mem3<br>V32 mem32, MR<br>DF32 MRd, MRe  | Ra              |                                      |  |  |

# MADDF32 MRa, MRb, #16FHi 32-Bit Floating-Point Addition

| perands             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                          |                                                                                                                                     |                                                            |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
|                     | MRa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CLA floating-point                                                                                                                                                                                                                  | destination register (MR                                                                                                                                                                                                                                                                                                 | R0 to MR3)                                                                                                                          |                                                            |
|                     | MRb                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CLA floating-point                                                                                                                                                                                                                  | source register (MR0 to                                                                                                                                                                                                                                                                                                  | 9 MR3)                                                                                                                              |                                                            |
|                     | #16FHi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                     | e value that represents t<br>w 16-bits of the mantiss                                                                                                                                                                                                                                                                    |                                                                                                                                     |                                                            |
| pcode               | LSW: IIII III                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                          |                                                                                                                                     |                                                            |
|                     | MSW: 0111 011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1 1100 bbaa                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                          |                                                                                                                                     |                                                            |
| escription          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | e floating-point val<br>ddition in MRa.                                                                                                                                                                                             | ue represented by t                                                                                                                                                                                                                                                                                                      | the immediate c                                                                                                                     | operand. Store the                                         |
|                     | floating-point v<br>most useful fo<br>Some example<br>(0xBFC00000)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | value. The low 16-b<br>r representing cons<br>es are 2.0 (0x4000<br>). The assembler w<br>lue -1.5 can be rep                                                                                                                       | ue that represents the tast of the mantissants where the low 0000), 4.0 (0x40800) ill accept either a h resented as #-1.5 c                                                                                                                                                                                              | are assumed to<br>vest 16-bits of t<br>0000), 0.5 (0x3I<br>ex or float as th                                                        | be all 0. #16FHi<br>he mantissa are 0<br>-000000), and -1. |
|                     | This instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | n can also be writte                                                                                                                                                                                                                | en as MADDF32 MF                                                                                                                                                                                                                                                                                                         | Ra, #16FHi, MR                                                                                                                      | b.                                                         |
| ags                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                     | wing flags in the MS                                                                                                                                                                                                                                                                                                     | -                                                                                                                                   |                                                            |
|                     | Flag T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                     | NF                                                                                                                                                                                                                                                                                                                       | LUF                                                                                                                                 | LVF                                                        |
|                     | Modified N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | o No                                                                                                                                                                                                                                | No                                                                                                                                                                                                                                                                                                                       |                                                                                                                                     | Yes                                                        |
|                     | • LUF = 1 if                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                                                                                                                                                                                                   | es an underflow co                                                                                                                                                                                                                                                                                                       | ndition.                                                                                                                            |                                                            |
| ipeline             | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if  </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | MADDF32 generate                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                          | ndition.                                                                                                                            |                                                            |
| ipeline<br>xample 1 | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; x is an arr.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an                                                                                                                             | es an underflow con<br>es an overflow conc<br>ing-point values                                                                                                                                                                                                                                                           | ndition.                                                                                                                            |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an                                                                                                                             | es an underflow con<br>es an overflow conc<br>ing-point values                                                                                                                                                                                                                                                           | ndition.                                                                                                                            |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>;</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an                                                                                                                             | es an underflow con<br>es an overflow conc<br>ing-point values                                                                                                                                                                                                                                                           | ndition.                                                                                                                            |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>;</li> <li>ClalTask1:</li> <li>MMOVI16</li> <li>MUI16TOF3</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result                                                                                                              | es an underflow con<br>es an overflow conc<br>ing-point values<br>array X<br>; Start address<br>; Length of the a                                                                                                                                                                                                        | ndition.<br>dition.                                                                                                                 |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>;</li> <li>_ClalTask1:</li> <li>_MMOVI16</li> <li>_MU16TOF3</li> <li>_MNOP</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X                                                                                                 | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1                                                                                                                                                                                    | ndition.<br>dition.<br>array<br>load                                                                                                |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>;</li> <li>ClalTask1:</li> <li>MMOVI16</li> <li>MUI16TOF3</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X                                                                                                 | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MARI<br>; delay for MARI                                                                                                                                                                | ndition.<br>dition.<br>array<br>load                                                                                                |                                                            |
| •                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>;</li> <li>_ClalTask1:</li> <li>_MMOVI16</li> <li>_MU16TOF3</li> <li>_MNOP</li> <li>_MNOP</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X<br>2 MR0, @_len                                                                                 | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MARI<br>; delay for MARI                                                                                                                                                                | ndition.<br>dition.<br>array<br>load                                                                                                |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an arra;</li> <li>; Find the max;</li> <li>; and store i</li> <li>;</li> <li>_ClalTask1:</li> <li>_MMOVI16</li> <li>_MU116TOF3</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MMOV32</li> <li>LOOP</li> <li>_MMOV32</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++                                           | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next elem                                                                                                                             | ndition.<br>dition.<br>array<br>load<br>load                                                                                        |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>; ClalTask1:</li> <li>MMOVI16</li> <li>MUI16TOF3</li> <li>MNOP</li> <li>MNOP</li> <li>MNOP</li> <li>MMOV32</li> <li>LOOP</li> <li>MMOV32</li> <li>MMOV32</li> <li>MMOV32</li> <li>MMOV32</li> <li>MMOV32</li> <li>MMAXF32</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2                               | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next elem<br>; MR1 = MAX(MR1,                                                                                                         | ndition.<br>dition.<br>array<br>load<br>load<br>ment<br>MR2)                                                                        |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>;</li> <li>_ClalTask1:</li> <li>_MMOV116</li> <li>_MU116TOF3</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MMOV32</li> <li>LOOP</li> <li>_MMOV32</li> <li>_MMOV33</li> <li>_MMOV34</li> <li>_MMOV34<!--</td--><td>MADDF32 generate<br/>MADDF32 generate<br/>e-cycle instruction.<br/>ay of 32-bit float<br/>ximum value in an<br/>t in Result<br/>MAR1, #_X<br/>2 MR0, @_len<br/>MR1, *MAR1[2]++<br/>MR2, *MAR1[2]++<br/>MR1, MR2<br/>MR0, MR0, #-1.0</td><td>es an underflow con<br/>es an overflow cond<br/>ing-point values<br/>array X<br/>; Start address<br/>; Length of the a<br/>; delay for MAR1<br/>; delay for MAR1<br/>; MR1 = X0<br/>; MR2 = next elem<br/>; MR1 = MAX(MR1,<br/>; Decrement the o</td><td>ndition.<br/>dition.<br/>dition.<br/>array<br/>load<br/>load<br/>ment<br/>MR2)<br/>counter</td><td></td></li></ul>                                                                                                             | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2<br>MR0, MR0, #-1.0            | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next elem<br>; MR1 = MAX(MR1,<br>; Decrement the o                                                                                    | ndition.<br>dition.<br>dition.<br>array<br>load<br>load<br>ment<br>MR2)<br>counter                                                  |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>; ClalTask1:</li> <li>MMOVI16</li> <li>MUI16TOF3</li> <li>MNOP</li> <li>MNOP</li> <li>MNOP</li> <li>MMOV32</li> <li>LOOP</li> <li>MMOV32</li> <li>MMOV32</li> <li>MMOV32</li> <li>MMOV32</li> <li>MMOV32</li> <li>MMAXF32</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2                               | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next elem<br>; MR1 = MAX(MR1,                                                                                                         | ndition.<br>dition.<br>dition.<br>array<br>load<br>load<br>ment<br>MR2)<br>counter                                                  |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>; ClalTask1:</li> <li>MMOVI16</li> <li>MUI16TOF3</li> <li>MNOP</li> <li>MNOP</li> <li>MMOV32</li> <li>LOOP</li> <li>MMOV32</li> <li>MMOV33</li> <li>MMOV34</li> <li>MMOV34&lt;</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2<br>MR0, MR0, #-1.0            | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next elem<br>; MR1 = MAX(MR1,<br>; Decrement the o                                                                                    | ndition.<br>dition.<br>dition.<br>array<br>load<br>load<br>ment<br>MR2)<br>counter                                                  |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an array</li> <li>; Find the max</li> <li>; and store i</li> <li>; ClalTask1:</li> <li>MMOVI16</li> <li>MUI16TOF3</li> <li>MNOP</li> <li>MNOP</li> <li>MMOV32</li> <li>LOOP</li> <li>MMOV32</li> <li>MMOV33</li> <li>MMOV33</li> <li>MMOV33</li> <li>MMOV34</li> <li>MMOV34</li> <li>MMOV35</li> <li>MMOV35</li> <li>MMOV35</li> <li>MMOV36</li> <li>MMOV37</li> <li>MMOV37&lt;</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1, #_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2<br>MR0, MR0, #-1.0            | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next elem<br>; MR1 = MAX(MR1,<br>; Decrement the o                                                                                    | ndition.<br>dition.<br>dition.<br>array<br>load<br>load<br>ment<br>MR2)<br>counter                                                  |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an arr.;</li> <li>; Find the max</li> <li>; and store i</li> <li>;</li> <li>_ClalTaskl:</li> <li>_MMOV16</li> <li>_MU16TOF3</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MMOV32</li> <li>LOOP</li> <li>_MMOV32</li> <li>LOOP</li> <li>_MMOV32</li> <li>_MMOV33</li> <li>_MMOV34</li> <li>_MMOV34</li> <li>_MMOV34</li> <li>_MMOV35</li> <li>_MMOV35</li> <li>_MMOV35</li> <li>_MMOV36</li> <li>_MMOV37</li> <li>_MMOV37<!--</td--><td>MADDF32 generate<br/>MADDF32 generate<br/>e-cycle instruction.<br/>ay of 32-bit float<br/>ximum value in an<br/>t in Result<br/>MAR1,#_X<br/>2 MR0, @_len<br/>MR1, *MAR1[2]++<br/>MR2, *MAR1[2]++<br/>MR1, MR2<br/>MR0, MR0, #-1.0<br/>MR0 #0.0</td><td>es an underflow con<br/>es an overflow cond<br/>ing-point values<br/>array X<br/>; Start address<br/>; Length of the a<br/>; delay for MAR1<br/>; delay for MAR1<br/>; delay for MAR1<br/>; MR1 = X0<br/>; MR2 = next eler<br/>; MR1 = MAX(MR1,<br/>; Decrement the a<br/>; Set/clear flags</td><td>ndition.<br/>dition.<br/>dition.<br/>array<br/>load<br/>load<br/>ment<br/>MR2)<br/>counter<br/>s for MBCNDD<br/>equal to zero</td><td></td></li></ul>                   | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1,#_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2<br>MR0, MR0, #-1.0<br>MR0 #0.0 | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next eler<br>; MR1 = MAX(MR1,<br>; Decrement the a<br>; Set/clear flags                                           | ndition.<br>dition.<br>dition.<br>array<br>load<br>load<br>ment<br>MR2)<br>counter<br>s for MBCNDD<br>equal to zero                 |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an arr;</li> <li>; Find the maa;</li> <li>; and store i</li> <li>;</li> <li>_ClalTaskl:</li> <li>_MMOVI16</li> <li>_MU16TOF3</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MMOV32</li> <li>LOOP</li> <li>_MMOV32</li> <li>_MMOV32</li> <li>_MMOP</li> <li>_MMOP32</li> <li>_MMOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MMOV32</li> <li>_MMOV32</li> <li>_MMOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MMOP</li> <li>_MNOP</li> <li>_MMOP</li> <li>_MM</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1,#_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2<br>MR0, MR0, #-1.0<br>MR0 #0.0 | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next eler<br>; MR1 = MAX(MR1,<br>; Decrement the o<br>; Set/clear flags<br>; Branch if not o<br>; Always executed | ndition.<br>dition.<br>dition.<br>array<br>load<br>load<br>ment<br>MR2)<br>counter<br>s for MBCNDD<br>equal to zero<br>d            |                                                            |
| -                   | <ul> <li>LUF = 1 if</li> <li>LVF = 1 if</li> <li>LVF = 1 if</li> <li>This is a single</li> <li>; X is an arr.;</li> <li>; Find the max</li> <li>; and store i</li> <li>;</li> <li>_ClalTaskl:</li> <li>_MMOV16</li> <li>_MU16TOF3</li> <li>_MNOP</li> <li>_MNOP</li> <li>_MMOV32</li> <li>LOOP</li> <li>_MMOV32</li> <li>LOOP</li> <li>_MMOV32</li> <li>_MMOV33</li> <li>_MMOV34</li> <li>_MMOV34</li> <li>_MMOV34</li> <li>_MMOV35</li> <li>_MMOV35</li> <li>_MMOV35</li> <li>_MMOV36</li> <li>_MMOV37</li> <li>_MMOV37<!--</td--><td>MADDF32 generate<br/>MADDF32 generate<br/>e-cycle instruction.<br/>ay of 32-bit float<br/>ximum value in an<br/>t in Result<br/>MAR1,#_X<br/>2 MR0, @_len<br/>MR1, *MAR1[2]++<br/>MR2, *MAR1[2]++<br/>MR1, MR2<br/>MR0, MR0, #-1.0<br/>MR0 #0.0</td><td>es an underflow con<br/>es an overflow cond<br/>ing-point values<br/>array X<br/>; Start address<br/>; Length of the a<br/>; delay for MAR1<br/>; delay for MAR1<br/>; delay for MAR1<br/>; MR1 = X0<br/>; MR2 = next eler<br/>; MR1 = MAX(MR1,<br/>; Decrement the a<br/>; Set/clear flags</td><td>ndition.<br/>dition.<br/>dition.<br/>dition.<br/>array<br/>load<br/>load<br/>nent<br/>MR2)<br/>counter<br/>s for MBCNDD<br/>equal to zero<br/>d</td><td></td></li></ul> | MADDF32 generate<br>MADDF32 generate<br>e-cycle instruction.<br>ay of 32-bit float<br>ximum value in an<br>t in Result<br>MAR1,#_X<br>2 MR0, @_len<br>MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2<br>MR0, MR0, #-1.0<br>MR0 #0.0 | es an underflow con<br>es an overflow cond<br>ing-point values<br>array X<br>; Start address<br>; Length of the a<br>; delay for MAR1<br>; delay for MAR1<br>; delay for MAR1<br>; MR1 = X0<br>; MR2 = next eler<br>; MR1 = MAX(MR1,<br>; Decrement the a<br>; Set/clear flags                                           | ndition.<br>dition.<br>dition.<br>dition.<br>array<br>load<br>load<br>nent<br>MR2)<br>counter<br>s for MBCNDD<br>equal to zero<br>d |                                                            |



| Instructio | n Set  |
|------------|--------|
| แม่งแน่งแบ | 11 000 |

| Example 2 | <pre>; Show the basic operation of MADDF32 ; ; Add to MR1 the value 2.0 in 32-bit floating-point format ; Store the result in MR0     MADDF32 MR0, MR1, #2.0 ; MR0 = MR1 + 2.0</pre>            |  |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|           | <pre>; Add to MR3 the value -2.5 in 32-bit floating-point format ; Store the result in MR2     MADDF32 MR2, MR3, #-2.5 ; MR2 = MR3 + (-2.5)</pre>                                               |  |  |  |  |  |
|           | <pre>; Add to MR0 the value 0x3FC00000 (1.5) ; Store the result in MR0 MADDF32 MR0, MR0, #0x3FC0 ; MR0 = MR0 + 1.5</pre>                                                                        |  |  |  |  |  |
| See also  | MADDF32 MRa, #16FHi, MRb<br>MADDF32 MRa, MRb, MRc<br>MADDF32 MRd, MRe, MRf    MMOV32 MRa, mem32<br>MADDF32 MRd, MRe, MRf    MMOV32 mem32, MRa<br>MMPYF32 MRa, MRb, MRc    MADDF32 MRd, MRe, MRf |  |  |  |  |  |

## MADDF32 MRa, MRb, MRc 32-Bit Floating-Point Addition

| Operands    |                                                                                              |                                                                                                                                                                                                                                                                  |                                          |                                               |                |     |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-----------------------------------------------|----------------|-----|--|--|--|--|
|             | MRa                                                                                          | CLA                                                                                                                                                                                                                                                              | floating-point de                        | stination register (M                         | R0 to MR3)     |     |  |  |  |  |
|             | MRb                                                                                          | MRb CLA floating-point source register (MR0 to MR3)                                                                                                                                                                                                              |                                          |                                               |                |     |  |  |  |  |
|             | MRc                                                                                          | CLA                                                                                                                                                                                                                                                              | floating-point so                        | urce register (MR0 t                          | o MR3)         |     |  |  |  |  |
| Opcode      | LSW: 000 000c bbaa<br>MSW: 0111 1100 0010 0000                                               |                                                                                                                                                                                                                                                                  |                                          |                                               |                |     |  |  |  |  |
| Description |                                                                                              | Add the contents of MRc to the contents of MRb and load the result into MRa.<br>MRa = MRb + MRc;                                                                                                                                                                 |                                          |                                               |                |     |  |  |  |  |
| Flags       | This instruct                                                                                | tion modifi                                                                                                                                                                                                                                                      | es the followin                          | ng flags in the M                             | ISTF register: |     |  |  |  |  |
|             | Flag                                                                                         | TF                                                                                                                                                                                                                                                               | ZF                                       | NF                                            | LUF            | LVF |  |  |  |  |
|             | Modified                                                                                     | No                                                                                                                                                                                                                                                               | No                                       | No                                            | Yes            | Yes |  |  |  |  |
| Pipeline    | • LUF = 1                                                                                    | if MADDF<br>if MADDF                                                                                                                                                                                                                                             | 32 generates                             | an underflow co<br>an overflow cor            |                |     |  |  |  |  |
| •           | 1113 13 4 311                                                                                | igic cycle i                                                                                                                                                                                                                                                     |                                          |                                               |                |     |  |  |  |  |
| Example     | ; Calculate<br>;<br>_ClalTask1:<br>MMOV32 M<br>MMOV32 M<br>MMPYF32<br>   MMOV32 M<br>MADDF32 | <pre>MMOV32 MR0,@M1 ; Load MR0 with M1 MMOV32 MR1,@X1 ; Load MR1 with X1 MMPYF32 MR1,MR1,MR0 ; Multiply M1*X1    MMOV32 MR0,@B1 ; and in parallel load MR0 with B1 MADDF32 MR1,MR1,MR0 ; Add M*X1 to B1 and store in MR1 MMOV32 @Y1,MR1 ; Store the result</pre> |                                          |                                               |                |     |  |  |  |  |
| See also    | MADDF32                                                                                      | MRa, MRb<br>MRd, MRe<br>MRd, MRe                                                                                                                                                                                                                                 | , #16FHi<br>, MRf    MMO<br>, MRf    MMO | V32 MRa, mem<br>V32 mem32, MI<br>DF32 MRd, MR | Ra             |     |  |  |  |  |



# MADDF32 MRd, MRe, MRf||MMOV32 mem32, MRa 32-Bit Floating-Point Addition with Parallel Move

| Operands    |                                                                                             |                                                                                                                                              |                                                                                 |                                                                                              |                                        |                                    |  |  |  |
|-------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------|------------------------------------|--|--|--|
| •           | MRd                                                                                         | MRd CLA floating-point destination register for the MADDF32 (MR0 to MR3)                                                                     |                                                                                 |                                                                                              |                                        |                                    |  |  |  |
|             | MRe                                                                                         | CLA floati                                                                                                                                   | CLA floating-point source register for the MADDF32 (MR0 to MR3)                 |                                                                                              |                                        |                                    |  |  |  |
|             | MRf                                                                                         | CLA floati                                                                                                                                   | ng-point source                                                                 | register for the                                                                             | MADDF32 (MR0 to N                      | 1R3)                               |  |  |  |
|             | mem32                                                                                       |                                                                                                                                              | nory location a<br>n of the MMOV                                                |                                                                                              | rect or indirect addre                 | ssing. This will be the            |  |  |  |
|             | MRa                                                                                         | CLA floati                                                                                                                                   | ng-point source                                                                 | register for the                                                                             | MMOV32 (MR0 to M                       | R3)                                |  |  |  |
| Opcode      |                                                                                             | mm mmmm mmmm<br>ee ddaa addr                                                                                                                 |                                                                                 |                                                                                              |                                        |                                    |  |  |  |
| Description |                                                                                             | ult in MRd. In                                                                                                                               |                                                                                 |                                                                                              | dd MRf to the co<br>ts of MRa to the a | ontents of MRe and 32-bit location |  |  |  |
| Flags       | This instructi                                                                              | on modifies th                                                                                                                               | e following                                                                     | lags in the M                                                                                | STF register:                          |                                    |  |  |  |
|             | Flag                                                                                        | TF 2                                                                                                                                         | ZF                                                                              | NF                                                                                           | LUF                                    | LVF                                |  |  |  |
|             | Modified                                                                                    | No I                                                                                                                                         | No                                                                              | No                                                                                           | Yes                                    | Yes                                |  |  |  |
| Pipeline    | • LVF = 1 i                                                                                 | f MADDF32 g<br>f MADDF32 g<br><sup>-</sup> 32 and MMO                                                                                        | enerates an                                                                     | overflow con                                                                                 | dition.                                |                                    |  |  |  |
| Example     | ; Calculate<br>;<br>;<br>_ClalTask2:<br>MMOV32<br>MMOV32<br>MMPYF32<br>   MMOV32<br>MADDF32 | and C are 32<br>Y2 = (A * B)<br>Y3 = (A * B)<br>MR0, @_A<br>MR1, @_B<br>MR1, MR1, MR0<br>MR0, @_C<br>MR1, MR1, MR0<br>@_Y2, MR1<br>@_Y3, MR1 | + C<br>; Load M<br>; Load M<br>) ; Multig<br>; ar<br>) ; Add ( <i>F</i><br>; ar | RO with A<br>Rl with B<br>bly A*B<br>d in paralle<br>*B) to C<br>d in paralle<br>the A*B + C | l load MR0 with                        | C                                  |  |  |  |
| See also    | MADDF32 M<br>MADDF32 M<br>MMPYF32 M                                                         | IRa, #16FHi, M<br>IRa, MRb, #16<br>IRa, MRb, MR<br>IRa, MRb, MR<br>IRd, MRe, MR                                                              | 8FHi<br>.c<br>.c    MADDF                                                       |                                                                                              |                                        |                                    |  |  |  |



# MADDF32 MRd, MRe, MRf ||MMOV32 MRa, mem32 32-Bit Floating-Point Addition with Parallel Move

| Operands     |                                                                                                                   |                                                                               |                                                                                  |                                                                                   |                                             |                                            |  |  |
|--------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------|--------------------------------------------|--|--|
|              | MRd                                                                                                               |                                                                               | 0.                                                                               | stination register for t<br>ame register as MRa                                   | · ·                                         | ) to MR3).                                 |  |  |
|              | MRe CLA floating-point source register for the MADDF32 (MR0 to MR3)                                               |                                                                               |                                                                                  |                                                                                   |                                             |                                            |  |  |
|              | MRf                                                                                                               |                                                                               |                                                                                  |                                                                                   |                                             |                                            |  |  |
|              | MRa                                                                                                               |                                                                               |                                                                                  | stination register for t<br>ame register as MRd                                   |                                             | to MR3).                                   |  |  |
|              | mem32                                                                                                             |                                                                               | memory locatic<br>MMOV32.                                                        | n accessed using dir                                                              | rect or indirect addre                      | essing. This is the sourc                  |  |  |
| Opcode       | LSW: mmmm mm<br>MSW: 0001 ff                                                                                      |                                                                               |                                                                                  |                                                                                   |                                             |                                            |  |  |
| Description  |                                                                                                                   | re the resu<br>Ra.<br><sub>MRf ;</sub>                                        |                                                                                  |                                                                                   |                                             | Rf to the contents c<br>le 32-bit location |  |  |
| Restrictions | The destination MRa and MR                                                                                        |                                                                               |                                                                                  |                                                                                   | 1MOV32 must b                               | e unique. That is,                         |  |  |
| lags         | This instruction                                                                                                  | on modifies                                                                   | the followir                                                                     | ng flags in the M                                                                 | STF register:                               |                                            |  |  |
| Flags        |                                                                                                                   |                                                                               |                                                                                  |                                                                                   |                                             |                                            |  |  |
|              | Flag                                                                                                              | TF                                                                            | ZF                                                                               | NF                                                                                | LUF                                         | LVF                                        |  |  |
|              | Modified                                                                                                          | No                                                                            | Yes                                                                              | Yes                                                                               | LUF<br>Yes                                  | LVF<br>Yes                                 |  |  |
|              | Modified<br>The MSTF re<br>• LUF = 1 if<br>• LVF = 1 if<br>The MMOV32                                             | No<br>egister flags<br>f MADDF32<br>f MADDF32<br>2 Instructio                 | Yes<br>are modifie<br>2 generates<br>2 generates                                 | Yes                                                                               | Yes<br>ndition.<br>dition.                  |                                            |  |  |
|              | Modified<br>The MSTF re<br>• LUF = 1 if<br>• LVF = 1 if                                                           | No<br>egister flags<br>f MADDF32<br><sup>6</sup> MADDF32<br>2 Instructio<br>; | Yes<br>are modifie<br>2 generates<br>2 generates<br>n will set the               | Yes<br>ed as follows:<br>an underflow col<br>an overflow cond<br>e NF and ZF flag | Yes<br>ndition.<br>dition.                  |                                            |  |  |
| Pipeline     | Modified<br>The MSTF re<br>• LUF = 1 if<br>• LVF = 1 if<br>The MMOV32<br>NF = MRa(31)<br>ZF = 0;<br>if(MRa(30:23) | No<br>gister flags<br>f MADDF32<br>MADDF32<br>2 Instructio<br>;<br>) == 0) {  | Yes<br>are modifie<br>2 generates<br>2 generates<br>n will set the<br>zF = 1; NF | Yes<br>ed as follows:<br>an underflow col<br>an overflow cond<br>e NF and ZF flag | Yes<br>ndition.<br>dition.<br>s as follows: |                                            |  |  |



| Example 2 | ; Given A, B and C are 32-1<br>; Calculate Y3 = (A + B) | oit floating-point numbers        |
|-----------|---------------------------------------------------------|-----------------------------------|
|           | ; $Y4 = (A + B) *$                                      | С                                 |
|           | ;                                                       |                                   |
|           | _ClalTask2:                                             |                                   |
|           | MMOV32 MR0, @A                                          | ; Load MRO with A                 |
|           | MMOV32 MR1, @B                                          | ; Load MR1 with B                 |
|           | MADDF32 MR1, MR1, MR0                                   | ; Add A+B                         |
|           |                                                         | ; and in parallel load MR0 with C |
|           |                                                         | ; Multiply (A+B) by C             |
|           |                                                         | ; and in parallel store A+B       |
|           |                                                         | ; Store the (A+B) * C             |
|           | MSTOP                                                   | ; end of task                     |
| See also  | MADDF32 MRa, #16FHi, MF                                 | Rb                                |
|           | MADDF32 MRa, MRb, #16F                                  | Hi                                |
|           | MADDF32 MRa, MRb, MRc                                   |                                   |
|           | MADDF32 MRd, MRe, MRf                                   | II MMO\/32 mem32 MRa              |
|           |                                                         | MADDF32 MRd, MRe, MRf             |

# MAND32 MRa, MRb, MRc Bitwise AND

| Operands    |                                                                      |                                                                                             |                      |                      |               |     |  |  |
|-------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------|----------------------|---------------|-----|--|--|
|             | MRa CLA floating-point destination register (MR0 to MR3)             |                                                                                             |                      |                      |               |     |  |  |
|             | MRb CLA floating-point source register (MR0 to MR3)                  |                                                                                             |                      |                      |               |     |  |  |
|             | MRc                                                                  | CLA                                                                                         | floating-point sou   | rce register (MR0 to | o MR3)        |     |  |  |
| Opcode      | LSW: 0000 000c bbaa<br>MSW: 0111 1100 0110 0000                      |                                                                                             |                      |                      |               |     |  |  |
| Description | Bitwise AND of MRb with MRc.<br>MRa(31:0) = MRb(31:0) AND MRc(31:0); |                                                                                             |                      |                      |               |     |  |  |
| Flags       | This instru                                                          | ction modifi                                                                                | es the followin      | g flags in the M     | STF register: |     |  |  |
| 0           | Flag                                                                 | TF                                                                                          | ZF                   | NF                   | LUF           | LVF |  |  |
|             | Modified                                                             | No                                                                                          | Yes                  | Yes                  | No            | No  |  |  |
| Pipeline    | NF = MRa(3<br>ZF = 0;<br>if(MRa(31:                                  | -                                                                                           | ZF = 1; }            | d based on the       |               |     |  |  |
| Fipeline    | 11115 15 a 5                                                         | ingle-cycle                                                                                 |                      |                      |               |     |  |  |
| Example     | MMOVIZ MR0, #0x5555; MR0 = 0x5555AAAA<br>MMOVXI MR0, #0xAAAA         |                                                                                             |                      |                      |               |     |  |  |
|             | MMOVIZ MR1, #0x5432 ; MR1 = 0x5432FEDC<br>MMOVXI MR1, #0xFEDC        |                                                                                             |                      |                      |               |     |  |  |
|             | ; 0101 ANI                                                           | 0101 = 01                                                                                   | 01 (5)               |                      |               |     |  |  |
|             |                                                                      | 0 0100 = 01                                                                                 |                      |                      |               |     |  |  |
|             |                                                                      | 0 0011 = 00<br>0 0010 = 00                                                                  |                      |                      |               |     |  |  |
|             | ; 1010 ANI                                                           | 0 1111 = 10                                                                                 | 10 (A)               |                      |               |     |  |  |
|             |                                                                      | 0 1110 = 10<br>0 1101 = 10                                                                  |                      |                      |               |     |  |  |
|             |                                                                      | p = 101 = 10<br>p = 10 = 10                                                                 |                      |                      |               |     |  |  |
|             | MAND32 MR2                                                           | 2, MR1, MR0                                                                                 | ; MR3 =              | 0x5410AA88           |               |     |  |  |
| See also    | MASR32 M<br>MLSL32 M<br>MLSR32 M<br>MOR32 M<br>MXOR32 I              | MRa, MRb,<br>MRa, #SHIF<br>IRa, #SHIF<br>MRa, #SHIF<br>Ra, MRb, M<br>MRa, MRb,<br>MRa, MRb, | T<br>T<br>TRc<br>MRc |                      |               |     |  |  |



# MASR32 MRa, #SHIFT Arithmetic Shift Right

| Operands    | MRa CLA floating-point source/destination register (MR0 to MR3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |                     |                   |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------|-------------------|--|--|--|--|
|             | MRa<br>#SHIFT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Number of bits t                                                                                                                                                                                                                                                                                                                                                                                                           | -                     |                     |                   |  |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |                     |                   |  |  |  |  |
| Opcode      | LSW: 0000 00<br>MSW: 0111 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |                     |                   |  |  |  |  |
| Description | Arithmetic shift right of MRa by the number of bits indicated. The number of bits can be 1 to 32.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |                     |                   |  |  |  |  |
|             | MARa(31:0) =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Arithmetic Shift                                                                                                                                                                                                                                                                                                                                                                                                           | (MARa(31:0) by #SH    | IFT bits);          |                   |  |  |  |  |
| Flags       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                            | lowing flags in the N | _                   |                   |  |  |  |  |
|             | - 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | TF ZF<br>No Yes                                                                                                                                                                                                                                                                                                                                                                                                            | NF<br>Yes             | LUF<br>No           | LVF<br>No         |  |  |  |  |
|             | Modified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | no res                                                                                                                                                                                                                                                                                                                                                                                                                     | Tes                   | INO                 |                   |  |  |  |  |
|             | NF = MRa(31)<br>ZF = 0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                            | odified based on the  | e integer results c | of the operation. |  |  |  |  |
| Pipeline    | This is a sing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | le-cycle instructior                                                                                                                                                                                                                                                                                                                                                                                                       | ۱.                    |                     |                   |  |  |  |  |
| Example     | <pre>; x2 = ; b2 = ; ; Calculate ; m2 = ; x2 = ; b2 = ; _ClalTask2:     MMOV32 MR     MMOV32 MR     MMOV32 MR     MASR32 MR</pre> | <pre>; Calculate<br/>; m2 = m2/2<br/>; x2 = x2/4<br/>; b2 = b2/8<br/>;<br/>ClalTask2:<br/>MMOV32 MR0, @_m2 ; MR0 = 32 (0x0000020)<br/>MMOV32 MR1, @_x2 ; MR1 = 64 (0x0000040)<br/>MMOV32 MR2, @_b2 ; MR2 = -128 (0xFFFFF80)<br/>MASR32 MR0, #1 ; MR0 = 16 (0x0000010)<br/>MASR32 MR1, #2 ; MR1 = 16 (0x0000010)<br/>MASR32 MR2, #3 ; MR2 = -16 (0xFFFFFF0)<br/>MMOV32 @_m2, MR0 ; store results<br/>MMOV32 @_x2, MR1</pre> |                       |                     |                   |  |  |  |  |
| See also    | MAND32 MR<br>MLSL32 MR<br>MLSR32 MR<br>MOR32 MR<br>MXOR32 MR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | a, #SHIFT                                                                                                                                                                                                                                                                                                                                                                                                                  |                       |                     |                   |  |  |  |  |



# MBCNDD 16BitDest {, CNDF} Branch Conditional Delayed

| Operands     |                                                                       |                                                                                             |                                                                                                                                                                                                                                                                  |                                                                                               |                                                                                          |
|--------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
|              | 16BitDest                                                             | 16-bit de                                                                                   | stination if condition is true                                                                                                                                                                                                                                   |                                                                                               |                                                                                          |
|              | CNDF                                                                  | Optional                                                                                    | condition tested                                                                                                                                                                                                                                                 |                                                                                               |                                                                                          |
| Opcode       |                                                                       | dest dest dest<br>1001 1000 cndf                                                            |                                                                                                                                                                                                                                                                  |                                                                                               |                                                                                          |
| Description  | MPC value<br>around. Th                                               | e. Otherwise, co<br>nerefore a value<br>. Since the MP0                                     | s true, then branch by adding the<br>ontinue without branching. If the<br>e of "0xFFFE" will put the MPC b<br>C is only 12-bits, unused bits the                                                                                                                 | address overflo<br>ack to the MBC                                                             | ows, it wraps<br>CNDD                                                                    |
|              | Please refe                                                           | er to the pipelin                                                                           | e section for important information                                                                                                                                                                                                                              | on regarding th                                                                               | is instruction.                                                                          |
|              | if (CNDF =                                                            | = TRUE) MPC +=                                                                              | = 16BitDest;                                                                                                                                                                                                                                                     |                                                                                               |                                                                                          |
|              | CNDF is o                                                             | ne of the follow                                                                            | ing conditions:                                                                                                                                                                                                                                                  |                                                                                               |                                                                                          |
|              | Encode <sup>(1)</sup>                                                 | CNDF                                                                                        | Description                                                                                                                                                                                                                                                      | MSTF Flags Te                                                                                 | sted                                                                                     |
|              | 0000                                                                  | NEQ                                                                                         | Not equal to zero                                                                                                                                                                                                                                                | ZF == 0                                                                                       |                                                                                          |
|              | 0001                                                                  | EQ                                                                                          | Equal to zero                                                                                                                                                                                                                                                    | ZF == 1                                                                                       |                                                                                          |
|              | 0010                                                                  | GT                                                                                          | Greater than zero                                                                                                                                                                                                                                                | ZF == 0 AND NF                                                                                | === 0                                                                                    |
|              | 0011                                                                  | GEQ                                                                                         | Greater than or equal to zero                                                                                                                                                                                                                                    | NF == 0                                                                                       |                                                                                          |
|              | 0100                                                                  | LT                                                                                          | Less than zero                                                                                                                                                                                                                                                   | NF == 1                                                                                       |                                                                                          |
|              | 0101                                                                  | LEQ                                                                                         | Less than or equal to zero                                                                                                                                                                                                                                       | ZF == 1 OR NF                                                                                 | == 1                                                                                     |
|              | 1010                                                                  | TF                                                                                          | Test flag set                                                                                                                                                                                                                                                    | TF == 1                                                                                       |                                                                                          |
|              | 1011                                                                  | NTF                                                                                         | Test flag not set                                                                                                                                                                                                                                                | TF == 0                                                                                       |                                                                                          |
|              | 1100                                                                  | LU                                                                                          | Latched underflow                                                                                                                                                                                                                                                | LUF == 1                                                                                      |                                                                                          |
|              | 1101                                                                  | LV                                                                                          | Latched overflow                                                                                                                                                                                                                                                 | LVF == 1                                                                                      |                                                                                          |
|              | 1110                                                                  | UNC                                                                                         | Unconditional                                                                                                                                                                                                                                                    | None                                                                                          |                                                                                          |
|              | 1111                                                                  | UNCF <sup>(2)</sup>                                                                         | Unconditional with flag modification                                                                                                                                                                                                                             | None                                                                                          |                                                                                          |
| Destrictions | <sup>(2)</sup> This is th be modif                                    | ied when a conditio                                                                         | if no CNDF field is specified. This condi<br>nal operation is executed. All other cond                                                                                                                                                                           | ditions will not mod                                                                          | ify these flags.                                                                         |
| Restrictions | MCCNDD                                                                | or MRCNDD in                                                                                | is not allowed three instructions struction. Refer to the pipeline s                                                                                                                                                                                             | ection for more                                                                               |                                                                                          |
| Flags        | -                                                                     |                                                                                             | modify flags in the MSTF registe                                                                                                                                                                                                                                 |                                                                                               |                                                                                          |
|              | Flag<br>Modified                                                      | TF<br>No                                                                                    | ZF NF<br>No No                                                                                                                                                                                                                                                   | No                                                                                            | LVF<br>No                                                                                |
|              | Wodilied                                                              | no                                                                                          |                                                                                                                                                                                                                                                                  |                                                                                               |                                                                                          |
| Pipeline     | for each bi<br>I4) and thr<br>taken or no<br>depends o<br>effective n | ranch 6 instruct<br>ee after the bra<br>ot taken depend<br>n how many sk<br>umber of cycles | by itself is a single-cycle instruct<br>ion slots are executed; three bef<br>nch instruction (I5-I7). The total<br>ds on the usage of these slots. T<br>bts are filled with a MNOP as we<br>s for a branch can, therefore, ran<br>anch taken may not be the same | fore the branch<br>number of cycl<br>That is, the num<br>ell as which slot<br>nge from 1 to 7 | instruction (I2-<br>es for a branch<br>ber of cycles<br>s are filled. The<br>cycles. The |
|              |                                                                       |                                                                                             |                                                                                                                                                                                                                                                                  |                                                                                               |                                                                                          |



Referring to Table 8-24 and Table 8-25, the instructions before and after MBCNDD have the following properties:

- I1
  - I1 is the last instruction that can effect the CNDF flags for the MBCNDD instruction. The CNDF flags are tested in the D2 phase of the pipeline. That is, a decision is made whether to branch or not when MBCNDD is in the D2 phase.
  - There are no restrictions on the type of instruction for I1.
- I2, I3 and I4
  - The three instructions proceeding MBCNDD can change MSTF flags but will have no effect on whether the MBCNDD instruction branches or not. This is because the flag modification will occur after the D2 phase of the MBCNDD instruction.
  - These instructions must not be the following: MSTOP, MDEBUGSTOP, MBCNDD, MCCNDD or MRCNDD.
- 15, 16 and 17
  - The three instructions following MBCNDD are always executed irrespective of whether the branch is taken or not.
  - These instructions must not be the following: MSTOP, MDEBUGSTOP, MBCNDD, MCCNDD or MRCNDD.

```
<Instruction 1>
                   ; Il Last instruction that can affect flags for
                   ; the MBCNDD operation
<Instruction 2>
                  ; I2 Cannot be stop, branch, call or return
<Instruction 3> ; I3 Cannot be stop, branch, call or return
<Instruction 4> ; I4 Cannot be stop, branch, call or return
MBCNDD _Skip, NEQ ; Branch to Skip if not eqal to zero
                   ; Three instructions after MBCNDD are always
                   ; executed whether the branch is taken or not
<Instruction 5> ; I5 Cannot be stop, branch, call or return
<Instruction 6> ; I6 Cannot be stop, branch, call or return
<Instruction 7> ; I7 Cannot be stop, branch, call or return
<Instruction 8> ; I8
<Instruction 9>
                  ; 19
. . . .
_Skip:
 <Destination 1> ; d1 Can be any instruction
 <Destination 2> ; d2
 <Destination 3> ; d3
. . . .
. . . .
MSTOP
. . . .
```

Instruction Set

| Instruction | F1         | F2     | D1     | D2     | R1  | R2  | Е   | w |
|-------------|------------|--------|--------|--------|-----|-----|-----|---|
| 11          | <b>I</b> 1 |        |        |        |     |     |     |   |
| 12          | 12         | 11     |        |        |     |     |     |   |
| 13          | 13         | 12     | 11     |        |     |     |     |   |
| 14          | 14         | 13     | 12     | 11     |     |     |     |   |
| MBCNDD      | MBCNDD     | 14     | 13     | 12     | l1  |     |     |   |
| 15          | 15         | MBCNDD | 14     | 13     | 12  | l1  |     |   |
| 16          | 16         | 15     | MBCNDD | 14     | 13  | 12  | 11  |   |
| 17          | 17         | 16     | 15     | MBCNDD | 14  | 13  | 12  |   |
| 18          | 18         | 17     | 16     | 15     | -   | 14  | 13  |   |
| 19          | 19         | 18     | 17     | 16     | 15  | -   | 14  |   |
| 110         | l10        | 19     | 18     | 17     | 16  | 15  | -   |   |
|             |            | I10    | 19     | 18     | 17  | 16  | 15  |   |
|             |            |        | I10    | 19     | 18  | 17  | 16  |   |
|             |            |        |        | l10    | 19  | 18  | 17  |   |
|             |            |        |        |        | l10 | 19  | 18  |   |
|             |            |        |        |        |     | l10 | 19  |   |
|             |            |        |        |        |     |     | I10 |   |

|             | Table 8-25. Pip | olino Ac | tivity Fo |        | D Bra | nch Tak | n . |   |
|-------------|-----------------|----------|-----------|--------|-------|---------|-----|---|
| Instruction | F1              | F2       | D1        | D2     | R1    | R2      | E   | w |
| 11          | l1              | •-       | 51        | 52     |       |         | -   |   |
| 12          | 12              | l1       |           |        |       |         |     |   |
| 13          | 13              | 12       | 11        |        |       |         |     |   |
| 14          | 14              | 13       | 12        | 11     |       |         |     |   |
| MBCNDD      | MBCNDD          | 14       | 13        | 12     | I1    |         |     |   |
| 15          | 15              | MBCNDD   | 14        | 13     | 12    | 11      |     |   |
| 16          | 16              | 15       | MBCNDD    | 14     | 13    | 12      | 11  |   |
| 17          | 17              | 16       | 15        | MBCNDD | 14    | 13      | 12  |   |
| d1          | d1              | 17       | 16        | 15     | -     | 14      | 13  |   |
| d2          | d2              | d1       | 17        | 16     | 15    | -       | 14  |   |
| d3          | d3              | d2       | d1        | 17     | 16    | 15      | -   |   |
|             |                 | d3       | d2        | d1     | 17    | 16      | 15  |   |
|             |                 |          | d3        | d2     | d1    | 17      | 16  |   |
|             |                 |          |           | d3     | d2    | d1      | 17  |   |
|             |                 |          |           |        | d3    | d2      | d1  |   |
|             |                 |          |           |        |       | d3      | d2  |   |
|             |                 |          |           |        |       |         | d3  |   |



```
www.ti.com
```

| Instruction  | Set |
|--------------|-----|
| 111301000001 | 061 |

| ; if (State == 0.1)<br>; RampState = RampState | 1   | RAMPMASK                            |  |  |  |  |  |
|------------------------------------------------|-----|-------------------------------------|--|--|--|--|--|
| ; else if (State == 0.01)                      |     |                                     |  |  |  |  |  |
| ; CoastState = CoastState    COASTMASK         |     |                                     |  |  |  |  |  |
| ; else                                         |     |                                     |  |  |  |  |  |
| ; SteadyState = SteadyStat                     | ۲a  | CTEADVMACK                          |  |  |  |  |  |
| ;                                              | cC. |                                     |  |  |  |  |  |
| ,<br>ClalTask1:                                |     |                                     |  |  |  |  |  |
| MMOV32 MR0, @State                             |     |                                     |  |  |  |  |  |
|                                                | ;   | Affects flags for 1st MBCNDD (A)    |  |  |  |  |  |
| MNOP                                           | '   | mileets flags for the measure (m)   |  |  |  |  |  |
| MNOP                                           |     |                                     |  |  |  |  |  |
| MNOP                                           |     |                                     |  |  |  |  |  |
|                                                | ;   | (A) If State != 0.1, go to Skipl    |  |  |  |  |  |
| MNOP ; Always executed                         | '   | (A) II BLUCE 0.1, 90 CO BRIPI       |  |  |  |  |  |
| MNOP ; Always executed                         |     |                                     |  |  |  |  |  |
| MNOP ; Always executed                         |     |                                     |  |  |  |  |  |
| -                                              | ;   | Execute if (A) branch not taken     |  |  |  |  |  |
|                                                |     | Execute if (A) branch not taken     |  |  |  |  |  |
| MOR32 MR1, MR2                                 |     | Execute if (A) branch not taken     |  |  |  |  |  |
| ,                                              |     | Execute if (A) branch not taken     |  |  |  |  |  |
| MSTOP                                          |     | end of task if (A) branch not taken |  |  |  |  |  |
| Skip1:                                         |     |                                     |  |  |  |  |  |
| 1                                              | ;   | Affects flags for 2nd MBCNDD (B)    |  |  |  |  |  |
| MNOP                                           |     |                                     |  |  |  |  |  |
| MNOP                                           |     |                                     |  |  |  |  |  |
| MNOP                                           |     |                                     |  |  |  |  |  |
| MBCNDD Skip2,NEQ                               | ;   | (B) If State != 0.01, go to Skip2   |  |  |  |  |  |
| MNOP ; Always executed                         |     |                                     |  |  |  |  |  |
| MNOP ; Always executed                         |     |                                     |  |  |  |  |  |
| MNOP ; Always executed                         |     |                                     |  |  |  |  |  |
| MMOV32 MR1, @CoastState                        | ;   | Execute if (B) branch not taken     |  |  |  |  |  |
| MMOVXI MR2, #COASTMASK                         | ;   | Execute if (B) branch not taken     |  |  |  |  |  |
| MOR32 MR1, MR2                                 | ;   | Execute if (B) branch not taken     |  |  |  |  |  |
|                                                | ;   | Execute if (B) branch not taken     |  |  |  |  |  |
| MSTOP                                          |     |                                     |  |  |  |  |  |
| Skip2:                                         |     |                                     |  |  |  |  |  |
| MMOV32 MR3, @SteadyState                       | ;   | Executed if (B) branch taken        |  |  |  |  |  |
| MMOVXI MR2, #STEADYMASK                        | ;   | Executed if (B) branch taken        |  |  |  |  |  |
|                                                |     | Executed if (B) branch taken        |  |  |  |  |  |
| MMOV32 @SteadyState, MR3                       | ;   | Executed if (B) branch taken        |  |  |  |  |  |
| MSTOP                                          |     |                                     |  |  |  |  |  |
|                                                |     |                                     |  |  |  |  |  |



| Example 2 | ; This example is the same                  | e as Example 1, except                                     |  |  |  |  |  |  |  |
|-----------|---------------------------------------------|------------------------------------------------------------|--|--|--|--|--|--|--|
|           | -                                           | o take advantage of delay slots                            |  |  |  |  |  |  |  |
|           | ;<br>; ;f (Stata == 0.1)                    |                                                            |  |  |  |  |  |  |  |
|           |                                             | ; if (State == 0.1)<br>; RampState = RampState    RAMPMASK |  |  |  |  |  |  |  |
|           | ; else if (State == 0.01)                   | KAPIEPIAGK                                                 |  |  |  |  |  |  |  |
|           | ; CoastState = CoastState                   | COASTMASK                                                  |  |  |  |  |  |  |  |
|           | ; else                                      |                                                            |  |  |  |  |  |  |  |
|           | ; SteadyState = SteadyStat                  | ce    STEADYMASK                                           |  |  |  |  |  |  |  |
|           | ;                                           |                                                            |  |  |  |  |  |  |  |
|           | _ClalTask2:                                 |                                                            |  |  |  |  |  |  |  |
|           | MMOV32 MR0, @State                          |                                                            |  |  |  |  |  |  |  |
|           | MCMPF32 MR0, #0.1                           | ; Affects flags for 1st MBCNDD (A)                         |  |  |  |  |  |  |  |
|           | MCMPF32 MRU, #0.01                          | ; Check used by 2nd MBCNDD (B)                             |  |  |  |  |  |  |  |
|           | MMTESTTF EQ<br>MNOP                         | ; Store EQ flag in TF for 2nd MBCNDD (B)                   |  |  |  |  |  |  |  |
|           |                                             | ; (A) If State != 0.1, go to Skipl                         |  |  |  |  |  |  |  |
|           | MMOV32 MR1, @RampState                      |                                                            |  |  |  |  |  |  |  |
|           | MMOVXI MR2, #RAMPMASK                       | ; Always executed                                          |  |  |  |  |  |  |  |
|           | MOR32 MR1, MR2                              | ; Always executed                                          |  |  |  |  |  |  |  |
|           | MMOV32 @RampState, MR1                      | ; Execute if (A) branch not taken                          |  |  |  |  |  |  |  |
|           | MSTOP                                       | ; end of task if (A) branch not taken                      |  |  |  |  |  |  |  |
|           | Skip1:                                      |                                                            |  |  |  |  |  |  |  |
|           | MMOV32 MR3, @SteadyState                    |                                                            |  |  |  |  |  |  |  |
|           | MMOVXI MR2, #STEADYMASK                     |                                                            |  |  |  |  |  |  |  |
|           | MOR32 MR3, MR2                              |                                                            |  |  |  |  |  |  |  |
|           | _                                           | ; (B) if State != .01, go to Skip2                         |  |  |  |  |  |  |  |
|           | MMOV32 MR1, @CoastState                     | -                                                          |  |  |  |  |  |  |  |
|           | MMOVXI MR2, #COASTMASK<br>MOR32 MR1, MR2    | _                                                          |  |  |  |  |  |  |  |
|           | ,                                           | ; Always executed<br>; Execute if (B) branch not taken     |  |  |  |  |  |  |  |
|           | MSTOP                                       | ; end of task if (B) branch not taken                      |  |  |  |  |  |  |  |
|           |                                             |                                                            |  |  |  |  |  |  |  |
|           | Skip2:<br>MMOV32 @SteadyState, MR3<br>MSTOP | ; Executed if (B) branch taken                             |  |  |  |  |  |  |  |
|           |                                             |                                                            |  |  |  |  |  |  |  |
| See also  | MCCNDD 16BitDest, CNDF<br>MRCNDD CNDF       |                                                            |  |  |  |  |  |  |  |



# MCCNDD 16BitDest {, CNDF} Call Conditional Delayed

| Operands     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                           |                                                           |                                                     |  |  |  |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------|--|--|--|--|
|              | 16BitDest                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | t 16-bit destination if condition is true |                                                           |                                                     |  |  |  |  |
|              | CNDF                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Optional condition                        | n to be tested                                            |                                                     |  |  |  |  |
| Opcode       | LSW: dest dest dest<br>MSW: 0111 1001 1001 cndf                                                                                                                                                                                                                                                                                                                                                                                                                              |                                           |                                                           |                                                     |  |  |  |  |
| Description  | If the specified condition is true, then store the return address in the RPC field of MSTF<br>and make the call by adding the signed 16BitDest value to the MPC value. Otherwise,<br>continue code execution without making the call. If the address overflows, it wraps<br>around. Therefore a value of "0xFFFE" will put the MPC back to the MCCNDD<br>instruction. Since the MPC is only 12 bits, unused bits the upper 4 bits of the destination<br>address are ignored. |                                           |                                                           |                                                     |  |  |  |  |
|              | <pre>Please refer to the pipeline section for important information regarding this instruction. if (CNDF == TRUE) {     RPC = return address;     MPC += 16BitDest; };</pre>                                                                                                                                                                                                                                                                                                 |                                           |                                                           |                                                     |  |  |  |  |
|              | Encode <sup>(3)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ne of the following cor<br>CNDF           |                                                           | NETE Flags Tested                                   |  |  |  |  |
|              | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | NEQ                                       | Description                                               | MSTF Flags Tested       ZF == 0                     |  |  |  |  |
|              | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | EQ                                        | Not equal to zero<br>Equal to zero                        | ZF == 0<br>ZF == 1                                  |  |  |  |  |
|              | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | GT                                        | Greater than zero                                         | ZF == 0 AND NF == 0                                 |  |  |  |  |
|              | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | GEQ                                       |                                                           | NF == 0                                             |  |  |  |  |
|              | 0100                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | LT                                        | Greater than or equal to zero<br>Less than zero           | NF == 1                                             |  |  |  |  |
|              | 0100                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | LEQ                                       |                                                           | ZF == 1 OR NF == 1                                  |  |  |  |  |
|              | 1010                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | TF                                        | Less than or equal to zero                                | TF == 1                                             |  |  |  |  |
|              | 1010                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | NTF                                       | Test flag set<br>Test flag not set                        | TF == 0                                             |  |  |  |  |
|              | 1100                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | LU                                        | Latched underflow                                         | LUF == 1                                            |  |  |  |  |
|              | 1100                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | LV                                        | Latched overflow                                          | LVF == 1                                            |  |  |  |  |
|              | 1110                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | UNC                                       | Unconditional                                             | None                                                |  |  |  |  |
|              | 1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | UNCF <sup>(4)</sup>                       | Unconditional with flag<br>modification                   | None                                                |  |  |  |  |
|              | <ul> <li>Values not shown are reserved.</li> <li><sup>(3)</sup> This is the default operation if no CNDF field is specified. This condition will allow the ZF and NF flags to be modified when a conditional operation is executed. All other conditions will not modify these flags.</li> </ul>                                                                                                                                                                             |                                           |                                                           |                                                     |  |  |  |  |
| Restrictions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                           | allowed three instructions<br>on. Refer to the Pipeline s | before or after a MBCNDD, section for more details. |  |  |  |  |
| Flags        | This instruction does not modify flags in the MSTF register.                                                                                                                                                                                                                                                                                                                                                                                                                 |                                           |                                                           |                                                     |  |  |  |  |

| This instruction does not moany hags in the morth register. |       |    |    |     |     |  |  |  |
|-------------------------------------------------------------|-------|----|----|-----|-----|--|--|--|
| Flag                                                        | TF    | ZF | NF | LUF | LVF |  |  |  |
| Modifi                                                      | ed No | No | No | No  | No  |  |  |  |

| Pipeline | The MCCNDD instruction by itself is a single-cycle instruction. As shown in Table 8-26, for each call 6 instruction slots are executed; three before the call instruction (I2-I4) and three after the call instruction (I5-I7). The total number of cycles for a call taken or not taken depends on the usage of these slots. That is, the number of cycles depends on how many slots are filled with a MNOP as well as which slots are filled. The effective number of cycles for a call can, therefore, range from 1 to 7 cycles. The number of cycles for a call taken may not be the same as for a call not taken. |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Referring to the following code fragment and the pipeline diagrams in Table 8-26 and Table 8-27, the instructions before and after MCCNDD have the following properties:                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|          | <ul> <li>I1         <ul> <li>I1 is the last instruction that can effect the CNDF flags for the MCCNDD instruction. The CNDF flags are tested in the D2 phase of the pipeline. That is, a decision is made whether to branch or not when MCCNDD is in the D2 phase.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                              |
|          | <ul> <li>There are no restrictions on the type of instruction for I1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          | • I2, I3 and I4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|          | <ul> <li>The three instructions proceeding MCCNDD can change MSTF flags but will have<br/>no effect on whether the MCCNDD instruction makes the call or not. This is<br/>because the flag modification will occur after the D2 phase of the MCCNDD<br/>instruction.</li> </ul>                                                                                                                                                                                                                                                                                                                                         |
|          | <ul> <li>These instructions must not be the following: MSTOP, MDEBUGSTOP,<br/>MBCNDD, MCCNDD or MRCNDD.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|          | • I5, I6 and I7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|          | <ul> <li>The three instructions following MBCNDD are always executed irrespective of<br/>whether the branch is taken or not.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | <ul> <li>These instructions must not be the following: MSTOP, MDEBUGSTOP,<br/>MBCNDD, MCCNDD or MRCNDD.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



| <instruction 1=""></instruction>  | ; Il Last instruction that can affect flags for<br>; the MCCNDD operation |
|-----------------------------------|---------------------------------------------------------------------------|
| <instruction 2=""></instruction>  | ; I2 Cannot be stop, branch, call or return                               |
| <instruction 3=""></instruction>  | ; I3 Cannot be stop, branch, call or return                               |
|                                   | ; I4 Cannot be stop, branch, call or return                               |
|                                   | , II callice be boop, branch, call of focall                              |
| MCCNDD _func, NEQ                 | ; Call to func if not eqal to zero                                        |
|                                   | ; Three instructions after MCCNDD are always                              |
|                                   | ; executed whether the call is taken or not                               |
| <instruction 5=""></instruction>  | ; I5 Cannot be stop, branch, call or return                               |
| <instruction 6=""></instruction>  | ; I6 Cannot be stop, branch, call or return                               |
| <instruction 7=""></instruction>  | ; I7 Cannot be stop, branch, call or return                               |
| <instruction 8=""></instruction>  | ; I8 The address of this instruction is saved                             |
|                                   | ; in the RPC field of the MSTF register.                                  |
|                                   | ; Upon return this value is loaded into MPC                               |
|                                   | ; and fetching continues from this point.                                 |
| <instruction 9=""></instruction>  | ; 19                                                                      |
| <br>_func:                        |                                                                           |
| <destination 1=""></destination>  | ; dl Can be any instruction                                               |
| <destination 2=""></destination>  | ; d2                                                                      |
| <destination 3=""></destination>  | ; d3                                                                      |
| <destination 4=""></destination>  | ; d4 Last instruction that can affect flags for                           |
|                                   | ; the MRCNDD operation                                                    |
| <destination 5=""></destination>  | ; d5 Cannot be stop, branch, call or return                               |
| <destination 6=""></destination>  | ; d6 Cannot be stop, branch, call or return                               |
| <destination 7=""></destination>  | ; d7 Cannot be stop, branch, call or return                               |
| MDONDD INIO                       | · Detum to Tretunction ()                                                 |
| MRCNDD, UNC                       | ; Return to <instruction 8="">, unconditional</instruction>               |
|                                   | ; Three instructions after MRCNDD are always                              |
|                                   | ; executed whether the return is taken or not                             |
| <destination 8=""></destination>  | ; d8 Cannot be stop, branch, call or return                               |
| <destination 9=""></destination>  | ; d9 Cannot be stop, branch, call or return                               |
| <destination 10=""></destination> | ; d10 Cannot be stop, branch, call or return                              |
| <destination 11=""></destination> | ; d11                                                                     |
|                                   |                                                                           |
| MSTOP                             |                                                                           |



| Table 8-26. Pipeline Activity For MCCNDD, Call Not Taken |        |        |        |        |     |            |     |   |
|----------------------------------------------------------|--------|--------|--------|--------|-----|------------|-----|---|
| Instruction                                              | F1     | F2     | D1     | D2     | R1  | R2         | Е   | w |
| 11                                                       | l1     |        |        |        |     |            |     |   |
| 2                                                        | 12     | l1     |        |        |     |            |     |   |
| 3                                                        | 13     | 12     | l1     |        |     |            |     |   |
| 4                                                        | 14     | 13     | 12     | 11     |     |            |     |   |
| MCCNDD                                                   | MCCNDD | 14     | 13     | 12     | l1  |            |     |   |
| 5                                                        | 15     | MCCNDD | 14     | 13     | 12  | <b>I</b> 1 |     |   |
| 6                                                        | 16     | 15     | MCCNDD | 14     | 13  | 12         | l1  |   |
| 7                                                        | 17     | 16     | 15     | MCCNDD | 14  | 13         | 12  |   |
| 8                                                        | 18     | 17     | 16     | 15     | -   | 14         | 13  |   |
| 9                                                        | 19     | 18     | 17     | 16     | 15  | -          | 14  |   |
| 10                                                       | 110    | 19     | 18     | 17     | 16  | 15         | -   |   |
| etc                                                      |        | l10    | 19     | 18     | 17  | 16         | 15  |   |
|                                                          |        |        | l10    | 19     | 18  | 17         | 16  |   |
|                                                          |        |        |        | l10    | 19  | 18         | 17  |   |
|                                                          |        |        |        |        | I10 | 19         | 18  |   |
|                                                          |        |        |        |        |     | l10        | 19  |   |
|                                                          |        |        |        |        |     |            | l10 |   |

# Table 8-27. Pipeline Activity For MCCNDD, Call Taken

|                  |        | •      | -      |        |    |    |    |   |
|------------------|--------|--------|--------|--------|----|----|----|---|
| Instruction      | F1     | F2     | D1     | D2     | R1 | R2 | Е  | w |
| 11               | l1     |        |        |        |    |    |    |   |
| 12               | 12     | l1     |        |        |    |    |    |   |
| 13               | 13     | 12     | 11     |        |    |    |    |   |
| 14               | 14     | 13     | 12     | 11     |    |    |    |   |
| MCCNDD           | MCCNDD | 14     | 13     | 12     | 11 |    |    |   |
| 15               | 15     | MCCNDD | 14     | 13     | 12 | l1 |    |   |
| 16               | 16     | 15     | MCCNDD | 14     | 13 | 12 | l1 |   |
| 7 <sup>(1)</sup> | 17     | 16     | 15     | MCCNDD | 14 | 13 | 12 |   |
| d1               | d1     | 17     | 16     | 15     | -  | 14 | 13 |   |
| d2               | d2     | d1     | 17     | 16     | 15 | -  | 14 |   |
| d3               | d3     | d2     | d1     | 17     | 16 | 15 | -  |   |
| etc              |        | d3     | d2     | d1     | 17 | 16 | 15 |   |
|                  |        |        | d3     | d2     | d1 | 17 | 16 |   |
|                  |        |        |        | d3     | d2 | d1 | 17 |   |
|                  |        |        |        |        | d3 | d2 | d1 |   |
|                  |        |        |        |        |    | d3 | d2 |   |
|                  |        |        |        |        |    |    | d3 |   |
|                  |        |        |        |        |    |    |    |   |

<sup>(1)</sup> The RPC value in the MSTF register will point to the instruction following I7 (instruction I8).

#### Example

See also

MBCNDD #16BitDest, CNDF MMOV32 mem32, MSTF MMOV32 MSTF, mem32 MRCNDD CNDF

;

Instruction Set



# MCMP32 MRa, MRb 32-Bit Integer Compare for Equal, Less Than or Greater Than

| O | pe | ra | n | h | 9 |
|---|----|----|---|---|---|
|   | μe | ıa |   | u | J |

| Operands    |                                                                                                                                                                                                                                                                                                                                                      |             |              |                  |               |     |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|------------------|---------------|-----|--|--|--|
|             | MRa CLA floating-point source register (MR0 to MR3)                                                                                                                                                                                                                                                                                                  |             |              |                  |               |     |  |  |  |
|             | MRb CLA floating-point source register (MR0 to MR3)                                                                                                                                                                                                                                                                                                  |             |              |                  |               |     |  |  |  |
| Opcode      | LSW: 0000 0000 bbaa<br>MSW: 0111 1111 0010 0000                                                                                                                                                                                                                                                                                                      |             |              |                  |               |     |  |  |  |
| Description | Set ZF and NF flags on the result of MRa - MRb where MRa and MRb are 32-bit integers. For a floating point compare refer to MCMPF32.                                                                                                                                                                                                                 |             |              |                  |               |     |  |  |  |
| Flags       | This instruction                                                                                                                                                                                                                                                                                                                                     | on modifies | the followin | g flags in the M | STF register: |     |  |  |  |
|             | Flag                                                                                                                                                                                                                                                                                                                                                 | TF          | ZF           | NF               | LUF           | LVF |  |  |  |
|             | Modified                                                                                                                                                                                                                                                                                                                                             | No          | Yes          | Yes              | No            | No  |  |  |  |
| Pipeline    | If(MRa > MR<br>If(MRa < MR<br>This is a sing                                                                                                                                                                                                                                                                                                         | b) {ZF=0; N | F=1;}        |                  |               |     |  |  |  |
| Example     | <pre>This is a single-cycle instruction. ; Behavior of ZF and NF flags for different comparisons ; ; Given A = (int32)1 ; B = (int32)2 ; C = (int32)-7 ;  MMOV32 MR0, @_A ; MR0 = 1 (0x0000001) MMOV32 MR1, @_B ; MR1 = 2 (0x0000002) MMOV32 MR2, @_C ; MR2 = -7 (0xFFFFFF9) MCMP32 MR2, MR2 ; NF = 0, ZF = 1 MCMP32 MR0, MR1 ; NF = 1, ZF = 0</pre> |             |              |                  |               |     |  |  |  |
| See also    | MADD32 MR<br>MSUB32 MR                                                                                                                                                                                                                                                                                                                               |             | c            | Ū                |               |     |  |  |  |



## MCMPF32 MRa, MRb 32-Bit Floating-Point Compare for Equal, Less Than or Greater Than

|                                                                                                                                                                                                                          | -                                                   |                                                                     |                                          |                                                                             |          |                     |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------|------------------------------------------|-----------------------------------------------------------------------------|----------|---------------------|--|--|--|--|
| Operands                                                                                                                                                                                                                 |                                                     |                                                                     |                                          |                                                                             |          |                     |  |  |  |  |
|                                                                                                                                                                                                                          | MRa                                                 | CL                                                                  | A floating-point so                      | urce register (MR0 t                                                        | o MR3)   |                     |  |  |  |  |
|                                                                                                                                                                                                                          | MRb                                                 | CL                                                                  | A floating-point so                      | urce register (MR0 t                                                        | o MR3)   |                     |  |  |  |  |
| Opcode                                                                                                                                                                                                                   | LSW: 0000<br>MSW: 0111                              |                                                                     |                                          |                                                                             |          |                     |  |  |  |  |
| DescriptionSet ZF and NF flags on the result of MRa - MRb. The MCMPF32 in<br>as a logical compare operation. This is possible because of the IEE<br>the exponent. Basically the bigger the binary number, the bigger the |                                                     |                                                                     |                                          |                                                                             |          | E format offsetting |  |  |  |  |
|                                                                                                                                                                                                                          | Special ca                                          | ses for inp                                                         | uts:                                     |                                                                             |          |                     |  |  |  |  |
|                                                                                                                                                                                                                          | <ul> <li>Negative</li> </ul>                        | /e zero wil                                                         | be treated as                            | positive zero.                                                              |          |                     |  |  |  |  |
|                                                                                                                                                                                                                          | <ul> <li>A deno</li> </ul>                          | rmalized v                                                          | alue will be tre                         | ated as positive                                                            | zero.    |                     |  |  |  |  |
|                                                                                                                                                                                                                          | <ul> <li>Not-a-N</li> </ul>                         | Number (N                                                           | aN) will be trea                         | ated as infinity.                                                           |          |                     |  |  |  |  |
| Flags                                                                                                                                                                                                                    | This instru                                         | This instruction modifies the following flags in the MSTF register: |                                          |                                                                             |          |                     |  |  |  |  |
| -                                                                                                                                                                                                                        | Flag                                                | TF                                                                  | ZF                                       | NF                                                                          | LUF      | LVF                 |  |  |  |  |
|                                                                                                                                                                                                                          | Modified                                            | No                                                                  | Yes                                      | Yes                                                                         | No       | No                  |  |  |  |  |
|                                                                                                                                                                                                                          | <pre>If(MRa == If(MRa &gt; N If(MRa &lt; N</pre>    | MRb) {Z<br>IRb) {ZF=0                                               | ,                                        | ed as follows:                                                              |          |                     |  |  |  |  |
| Pipeline                                                                                                                                                                                                                 | This is a s                                         | ingle-cycle                                                         | instruction.                             |                                                                             |          |                     |  |  |  |  |
| Example                                                                                                                                                                                                                  | ; Behavior                                          | of ZF and                                                           | d NF flags for                           | different comp                                                              | parisons |                     |  |  |  |  |
|                                                                                                                                                                                                                          | MMOVII<br>MMOVII<br>MCMPF<br>MCMPF                  | MR0,<br>32 MR1, 1<br>32 MR0, 1                                      | #5.0 ; MR0 =<br>MR0 ; ZF =<br>MR1 ; ZF = | = -2.0 (0xC00000<br>= 5.0 (0x40A0000<br>0, NF = 1<br>0, NF = 0<br>1, NF = 0 |          |                     |  |  |  |  |
| See also                                                                                                                                                                                                                 | MCMPF32<br>MMAXF32<br>MMAXF32<br>MMINF32<br>MMINF32 | MRa, #16<br>MRa, MR<br>MRa, #16                                     | iFHi<br>b<br>FHi                         |                                                                             |          |                     |  |  |  |  |

# MCMPF32 MRa, #16FHi 32-Bit Floating-Point Compare for Equal, Less Than or Greater Than

| 0 | pe | r n | n | Ч | ~ |
|---|----|-----|---|---|---|
| U | De | ra  | n | α | s |

| Operands    |                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                    |          |     |  |  |  |
|-------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------|-----|--|--|--|
|             | MRa                                                           | CLA floating-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | point source register (MR0 t                                                                       | o MR3)   |     |  |  |  |
|             | #16FHi                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | diate value that represents he low 16-bits of the mantis                                           |          |     |  |  |  |
| Opcode      | LSW: IIII II<br>MSW: 0111 10                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                    |          |     |  |  |  |
| Description |                                                               | Compare the value in MRa with the floating-point value represented by the immediate operand. Set the ZF and NF flags on (MRa - #16FHi:0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                    |          |     |  |  |  |
|             | floating-point<br>addressing m<br>are 0. Some<br>-1.5 (0xBFC0 | <ul> <li>#16FHi is a 16-bit immediate value that represents the upper 16-bits of an IEEE 32-bit floating-point value. The low 16-bits of the mantissa are assumed to be all 0. This addressing mode is most useful for constants where the lowest 16-bits of the mantissa are 0. Some examples are 2.0 (0x4000000), 4.0 (0x40800000), 0.5 (0x3F000000), and -1.5 (0xBFC00000). The assembler will accept either a hex or float as the immediate value. That is, -1.5 can be represented as #-1.5 or #0xBFC0.</li> <li>The MCMPF32 instruction is performed as a logical compare operation. This is possible because of the IEEE floating-point format offsets the exponent. Basically the bigger the binary number, the bigger the floating-point value.</li> </ul> |                                                                                                    |          |     |  |  |  |
|             | because of the                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                    |          |     |  |  |  |
|             | Special case                                                  | Special cases for inputs:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                    |          |     |  |  |  |
|             | Negative                                                      | <ul> <li>Negative zero will be treated as positive zero.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                    |          |     |  |  |  |
|             | Denormal                                                      | <ul> <li>Denormalized value will be treated as positive zero.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                    |          |     |  |  |  |
|             | <ul> <li>Not-a-Nui</li> </ul>                                 | mber (NaN) will I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | be treated as infinity.                                                                            |          |     |  |  |  |
| Flags       | This instructi                                                | This instruction modifies the following flags in the MSTF register:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                    |          |     |  |  |  |
| i lags      |                                                               | TF ZF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | NF                                                                                                 | LUF      | LVF |  |  |  |
|             | - 5                                                           | No Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                    | No       | No  |  |  |  |
|             | The MSTF register flags are modified as follows:              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                    |          |     |  |  |  |
|             |                                                               | 6FHi:0) {ZF=1<br>FHi:0) {ZF=0, N<br>FHi:0) {ZF=0, N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                    |          |     |  |  |  |
| Pipeline    | This is a sing                                                | le-cycle instructi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | on                                                                                                 |          |     |  |  |  |
| Example 1   | ; Behavior o                                                  | f ZF and NF fla                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | gs for different comp                                                                              | parisons |     |  |  |  |
|             | MMOVIZ<br>MMOVIZ<br>MCMPF32<br>MCMPF32<br>MCMPF32             | MRO, #5.0 ;<br>MR1, #-2.2 ;<br>MRO, #6.5 ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MR1 = -2.0 (0xC00000<br>MR0 = 5.0 (0x40A0000<br>ZF = 0, NF = 0<br>ZF = 0, NF = 1<br>ZF = 1, NF = 0 |          |     |  |  |  |



| www.ti.com |                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Example 2  | ; X is an array of 32-bit floating-point values<br>; and has len elements. Find the maximum value in<br>; the array and store it in Result<br>;<br>; Note: MCMPF32 and MSWAPF can be replaced with MMAXF32<br>;                                                         |  |  |  |  |  |
|            | _ClalTask1:<br>MMOVI16 MAR1,#_X ; Start address<br>MUI16TOF32 MR0, @_len ; Length of the array<br>MNOP ; delay for MAR1 load<br>MNOP ; delay for MAR1 load<br>MMOV32 MR1, *MAR1[2]++ ; MR1 = X0                                                                         |  |  |  |  |  |
|            | LOOP<br>MMOV32 MR2, *MAR1[2]++ ; MR2 = next element<br>MCMPF32 MR2, MR1 ; Compare MR2 with MR1<br>MSWAPF MR1, MR2, GT ; MR1 = MAX(MR1, MR2)<br>MADDF32 MR0, MR0, #-1.0 ; Decrement the counter<br>MCMPF32 MR0 #0.0 ; Set/clear flags for MBCNDD<br>MNOP<br>MNOP<br>MNOP |  |  |  |  |  |
|            | MNOP<br>MBCNDD LOOP, NEQ ; Branch if not equal to zero<br>MMOV32 @_Result, MR1 ; Always executed<br>MNOP ; Always executed<br>MNOP ; Always executed<br>MSTOP ; End of task                                                                                             |  |  |  |  |  |
| See also   | MCMPF32 MRa, MRb<br>MMAXF32 MRa, #16FHi<br>MMAXF32 MRa, MRb<br>MMINF32 MRa, #16FHi<br>MMINF32 MRa, MRb                                                                                                                                                                  |  |  |  |  |  |



|                       | Debug Stop Task                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                |                                                            |                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                |  |  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|
| Operands              |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                |                                                            |                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                |  |  |
|                       | none                                                                                                                                                                                                                                                                                                                                                                                                                                                | Th                                             | is instruction does                                        | not have any opera                                       | nds                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |  |  |
| Dpcode                | LSW: 0000 0000 0000<br>MSW: 0111 1111 0110 0000                                                                                                                                                                                                                                                                                                                                                                                                     |                                                |                                                            |                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                |  |  |
| Description           | When CLA breakpoints are enabled, the MDEBUGSTOP instruction is used to halt a task so that it can be debugged. That is, MDEBUGSTOP is the CLA breakpoint. If CLA breakpoints are not enabled, the MDEBUGSTOP instruction behaves like a MNOP. Unlike the MSTOP, the MIRUN flag is not cleared and an interrupt is not issued. A single-step or run operation will continue execution of the task.<br>The MDEBUGSTOP instructions before or after a |                                                |                                                            |                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                |  |  |
| Restrictions          | The MDE                                                                                                                                                                                                                                                                                                                                                                                                                                             | BUGSTOP                                        | instruction car                                            | not be placed 3                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                |  |  |
| Restrictions          | The MDEI<br>MBCNDD                                                                                                                                                                                                                                                                                                                                                                                                                                  | BUGSTOP<br>, MCCNDE                            | instruction car                                            | nnot be placed 3 instruction.                            | instructions before                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |  |  |
| Restrictions<br>Flags | The MDEI<br>MBCNDD                                                                                                                                                                                                                                                                                                                                                                                                                                  | BUGSTOP<br>, MCCNDE                            | instruction car<br>or MRCNDD<br>not modify fla             | nnot be placed 3<br>instruction.<br>gs in the MSTF       | instructions before the second seco | ore or after a |  |  |
|                       | The MDEI<br>MBCNDD                                                                                                                                                                                                                                                                                                                                                                                                                                  | BUGSTOP<br>, MCCNDE                            | instruction car                                            | nnot be placed 3 instruction.                            | instructions before                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |  |  |
| lags                  | The MDEI<br>MBCNDD<br>This instru<br>Flag<br>Modified                                                                                                                                                                                                                                                                                                                                                                                               | BUGSTOP<br>, MCCNDE<br>uction does<br>TF<br>No | instruction car<br>or MRCNDD<br>not modify fla<br>ZF       | nnot be placed 3<br>instruction.<br>gs in the MSTF<br>NF | instructions before<br>register.<br>LUF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ore or after a |  |  |
|                       | The MDEI<br>MBCNDD<br>This instru<br>Flag<br>Modified                                                                                                                                                                                                                                                                                                                                                                                               | BUGSTOP<br>, MCCNDE<br>uction does<br>TF<br>No | instruction car<br>or MRCNDD<br>not modify fla<br>ZF<br>No | nnot be placed 3<br>instruction.<br>gs in the MSTF<br>NF | instructions before<br>register.<br>LUF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ore or after a |  |  |



| www.ti.com  |                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                           |                           |                                    |           | Instruction Set           |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------------|-----------|---------------------------|--|
| MEALLOW     | Enable CLA Write Access to EALLOW Protected Registers                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                           |                           |                                    |           |                           |  |
| Operands    |                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                           |                           |                                    |           |                           |  |
|             | none                                                                                                                                                                                                                                               | TI                                                                                                                                                                                                                                                                                                                                                                                                                        | his instruction does      | s not have any opera               | inds      |                           |  |
| Opcode      | LSW: 0000 0000 0000<br>MSW: 0111 1111 1001 0000                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                           |                           |                                    |           |                           |  |
| Description | This instruction sets the MEALLOW bit in the CLA status register MSTF. When this bit is set, the CLA is allowed write access to EALLOW protected registers. To again protect against CLA writes to protected registers, use the MEDIS instruction. |                                                                                                                                                                                                                                                                                                                                                                                                                           |                           |                                    |           |                           |  |
|             | MEALLO<br>the main<br>main CPL                                                                                                                                                                                                                     | MEALLOW and MEDIS only control CLA write access; reads are allowed even if<br>MEALLOW has not been executed. MEALLOW and MEDIS are also independant from<br>the main CPU's EALLOW/EDIS. This instruction does not modify the EALLOW bit in the<br>main CPU's status register. The MEALLOW bit in MSTF only controls access for the<br>CLA while the EALLOW bit in the ST1 register only controls access for the main CPU. |                           |                                    |           |                           |  |
|             |                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                           |                           | bit is overridden<br>from Code Com |           | rt, allowing full control |  |
| Flags       | This instru                                                                                                                                                                                                                                        | uction does                                                                                                                                                                                                                                                                                                                                                                                                               | s not modify fla          | igs in the MSTF                    | register. |                           |  |
|             | Flag                                                                                                                                                                                                                                               | TF                                                                                                                                                                                                                                                                                                                                                                                                                        | ZF                        | NF                                 | LUF       | LVF                       |  |
|             | Modified                                                                                                                                                                                                                                           | No                                                                                                                                                                                                                                                                                                                                                                                                                        | No                        | No                                 | No        | No                        |  |
| Pipeline    | This is a s                                                                                                                                                                                                                                        | single-cycl                                                                                                                                                                                                                                                                                                                                                                                                               | e instruction.            |                                    |           |                           |  |
| Example     |                                                                                                                                                                                                                                                    | r file ind<br>mlRegs str                                                                                                                                                                                                                                                                                                                                                                                                  | cluding defini<br>ructure | tion of                            |           |                           |  |

; The ePWM TZSEL register is EALLOW protected

MMOV16 @\_EPwm1Regs.TZSEL.all, MR3 ; Write to TZSEL

.cdecls C,LIST,"CLAShared.h"

See also

**MEDIS** 

. . . \_ClalTask1: . . .

MEALLOW

MEDIS

. . . • • • MSTOP

;

;

; Allow CLA write access

; Disallow CLA write access



| MEDIS       | Disable C                                                                                                                       | CLA Write                                                                                                                                                                                                                                                                                                                                                                                                                 | Access to EA         | LOW Protecte                     | ed Registers                              |                                          |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|----------------------------------|-------------------------------------------|------------------------------------------|--|--|
| Operands    |                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                           |                      |                                  |                                           |                                          |  |  |
|             | none                                                                                                                            | Tł                                                                                                                                                                                                                                                                                                                                                                                                                        | nis instruction does | not have any opera               | ands                                      |                                          |  |  |
| Opcode      |                                                                                                                                 | 0000 0000<br>1111 1011                                                                                                                                                                                                                                                                                                                                                                                                    |                      |                                  |                                           |                                          |  |  |
| Description | is clear, th                                                                                                                    | ne CLA is i                                                                                                                                                                                                                                                                                                                                                                                                               | not allowed writ     |                                  | LLOW protected                            | MSTF. When this bit registers. To enable |  |  |
|             | MEALLO<br>the main (<br>main CPL                                                                                                | MEALLOW and MEDIS only control CLA write access; reads are allowed even if<br>MEALLOW has not been executed. MEALLOW and MEDIS are also independent from<br>the main CPU's EALLOW/EDIS. This instruction does not modify the EALLOW bit in the<br>main CPU's status register. The MEALLOW bit in MSTF only controls access for the<br>CLA while the EALLOW bit in the ST1 register only controls access for the main CPU. |                      |                                  |                                           |                                          |  |  |
|             |                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                           |                      | it is overridden<br>rom Code Com |                                           | rt, allowing full control                |  |  |
| Flags       |                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                           |                      | gs in the MSTF                   | -                                         |                                          |  |  |
|             | Flag<br>Modified                                                                                                                | TF<br>No                                                                                                                                                                                                                                                                                                                                                                                                                  | ZF                   | NF                               | LUF                                       | LVF<br>No                                |  |  |
| Pipeline    | This is a s                                                                                                                     | single-cycle                                                                                                                                                                                                                                                                                                                                                                                                              | e instruction.       |                                  |                                           |                                          |  |  |
| Example     | <pre>; C header file including definition of ; the EPwmlRegs structure ; ; The ePWM TZSEL register is EALLOW protected ; </pre> |                                                                                                                                                                                                                                                                                                                                                                                                                           |                      |                                  |                                           |                                          |  |  |
|             | .cdecls C,LIST,"CLAShared.h"<br><br>ClalTask1:                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                           |                      |                                  |                                           |                                          |  |  |
|             | MEDIS                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                           | egs.TZSEL.all,       | MR3 ; Write to                   | A write access<br>TZSEL<br>CLA write acce | 55                                       |  |  |
| See also    | MSTOP<br>MEALLO                                                                                                                 | Λ/                                                                                                                                                                                                                                                                                                                                                                                                                        |                      |                                  |                                           |                                          |  |  |



## MEINVF32 MRa, MRb 32-Bit Floating-Point Reciprocal Approximation

| Operands    |                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                     |                                  |                |     |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------------------|----------------|-----|--|--|--|
|             | MRa                                                                                                                                                                            | CL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | A floating-point de | stination register (N            | IR0 to MR3)    |     |  |  |  |
|             | MRb                                                                                                                                                                            | CL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | A floating-point so | urce register (MR0               | to MR3)        |     |  |  |  |
| Opcode      | LSW: 0000 0000 bbaa<br>MSW: 0111 1111 0000 0000                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                     |                                  |                |     |  |  |  |
| Description | approxima<br>more acc<br>Ye = Esti<br>Ye = Ye*(<br>Ye = Ye*(<br>After two<br>accurate<br>approxima<br>DeNorm of                                                                | <pre>This operation generates an estimate of 1/X in 32-bit floating-point format accurate to approximately 8 bits. This value can be used in a Newton-Raphson algorithm to get a more accurate answer. That is:     Ye = Estimate(1/X);     Ye = Ye*(2.0 - Ye*X);     Ye = Ye*(2.0 - Ye*X);     After two iterations of the Newton-Raphson algorithm, you will get an exact answer accurate to the 32-bit floating-point format. On each iteration the mantissa bit accuracy approximately doubles. The MEINVF32 operation will not generate a negative zero, DeNorm or NaN value.     MRa = Estimate of 1/MRb;</pre> |                     |                                  |                |     |  |  |  |
| Flags       | This instru                                                                                                                                                                    | uction modif                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ies the followi     | ng flags in the M                | ISTF register: |     |  |  |  |
|             | Flag                                                                                                                                                                           | TF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ZF                  | NF                               | LUF            | LVF |  |  |  |
|             | Modified                                                                                                                                                                       | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | No                  | No                               | Yes            | Yes |  |  |  |
| Pipeline    | • LVF =                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F32 generates       | an underflow c<br>an overflow co |                |     |  |  |  |
| Example     | <pre>; Calculate Num/Den using a Newton-Raphson algorithum for 1/Den<br/>; Ye = Estimate(1/X)<br/>; Ye = Ye*(2.0 - Ye*X)<br/>; Ye = Ye*(2.0 - Ye*X)<br/>;<br/>ClalTask1:</pre> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                     |                                  |                |     |  |  |  |
| See also    | MEISQRI                                                                                                                                                                        | TF32 MRa, I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | MRb                 |                                  |                |     |  |  |  |



# MEISQRTF32 MRa, MRb 32-Bit Floating-Point Square-Root Reciprocal Approximation

#### Operands

| Operands    |                                                                                                                                                                                   |                                                                                                                                                                                                                  |                                                                              |                                                                               |                      |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------|--|--|--|--|
|             | MRa                                                                                                                                                                               | CLA floating-                                                                                                                                                                                                    | point destination register (N                                                | IR0 to MR3)                                                                   |                      |  |  |  |  |
|             | MRb                                                                                                                                                                               | CLA floating-                                                                                                                                                                                                    | point source register (MR0                                                   | to MR3)                                                                       |                      |  |  |  |  |
| Opcode      |                                                                                                                                                                                   | LSW: 0000 0000 bbaa<br>MSW: 0111 1110 0100 0000                                                                                                                                                                  |                                                                              |                                                                               |                      |  |  |  |  |
| Description | to approxir                                                                                                                                                                       | This operation generates an estimate of 1/sqrt(X) in 32-bit floating-point format accurate to approximately 8 bits. This value can be used in a Newton-Raphson algorithm to get a more accurate answer. That is: |                                                                              |                                                                               |                      |  |  |  |  |
|             | Ye = Ye*(1                                                                                                                                                                        | ate(1/sqrt(X));<br>.5 - Ye*Ye*X/2.0)<br>.5 - Ye*Ye*X/2.0)                                                                                                                                                        |                                                                              |                                                                               |                      |  |  |  |  |
|             | accurate to<br>approximat<br>DeNorm or                                                                                                                                            | the 32-bit floating                                                                                                                                                                                              | on-Raphson algorithm<br>-point format. On eac<br>MEISQRTF32 operatio<br>Rb); | h iteration the ma                                                            | intissa bit accuracy |  |  |  |  |
| Flags       |                                                                                                                                                                                   |                                                                                                                                                                                                                  | following flags in the N                                                     |                                                                               |                      |  |  |  |  |
|             | Flag                                                                                                                                                                              | TF ZF                                                                                                                                                                                                            | NF                                                                           | LUF                                                                           | LVF                  |  |  |  |  |
|             | Modified                                                                                                                                                                          | No No                                                                                                                                                                                                            | No                                                                           | Yes                                                                           | Yes                  |  |  |  |  |
| Pipeline    |                                                                                                                                                                                   | ngle-cycle instruct                                                                                                                                                                                              | generates an overflow<br>ion.                                                |                                                                               |                      |  |  |  |  |
| Example     | ; Ye = Ye*<br>; Ye = Ye*<br>; Y = X*Ye<br>;<br>_ClalTask3<br>MMOV32<br>MEISQR<br>MMOV32<br>MMPYF3<br>MMPYF3<br>MMPYF3<br>MMPYF3<br>MMPYF3<br>MSUBF3<br>MMPYF3<br>MMPYF3<br>MMPYF3 | <pre>imate(1/sqrt(X));<br/>(1.5 - Ye*Ye*X*0.<br/>(1.5 - Ye*Ye*X*0.<br/>:<br/>MR0, @_x<br/>TF32 MR1, MR0</pre>                                                                                                    | 5)                                                                           | = 0.0<br>5<br>e*X*0.5<br>.5 - Ye*Ye*X*0.5<br>5<br>e*X*0.5<br>.5 - Ye*Ye*X*0.5 |                      |  |  |  |  |
| See also    | MSTOP                                                                                                                                                                             | MRa MRb                                                                                                                                                                                                          | ; end of task                                                                | ,                                                                             |                      |  |  |  |  |

See also

MEINVF32 MRa, MRb



# MF32TOI16 MRa, MRb Convert 32-Bit Floating-Point Value to 16-Bit Integer

| operanae    |                                                            |                                                                                                                  |                           |                  |                 |                      |  |  |  |  |
|-------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------|------------------|-----------------|----------------------|--|--|--|--|
|             | MRa                                                        | CLA flo                                                                                                          | pating-point destinat     | ion register (MF | R0 to MR3)      |                      |  |  |  |  |
|             | MRb                                                        | CLA flo                                                                                                          | pating-point source r     | egister (MR0 to  | o MR3)          |                      |  |  |  |  |
|             |                                                            |                                                                                                                  |                           |                  |                 |                      |  |  |  |  |
| Opcode      | LSW: 0000 (                                                | 0000 0000 bb                                                                                                     | aa                        |                  |                 |                      |  |  |  |  |
|             | MSW: 0111 1                                                | 1101 1110 00                                                                                                     | 00                        |                  |                 |                      |  |  |  |  |
| Description |                                                            | Convert a 32-bit floating point value in MRb to a 16-bit integer and truncate. The result will be stored in MRa. |                           |                  |                 |                      |  |  |  |  |
|             |                                                            | = F32TOI16(M<br>= sign exte                                                                                      | Rb);<br>nsion of MRa(15   | );               |                 |                      |  |  |  |  |
| Flags       | This instruc                                               | tion does no                                                                                                     | t affect any flags        | 8:               |                 |                      |  |  |  |  |
|             | Flag                                                       | TF                                                                                                               | ZF                        | NF               | LUF             | LVF                  |  |  |  |  |
|             | Modified                                                   | No                                                                                                               | No                        | No               | No              | No                   |  |  |  |  |
| Pipeline    | This is a si                                               | ngle-cycle ins                                                                                                   | struction.                |                  |                 |                      |  |  |  |  |
| Example     | MMOVIZ                                                     | MMOVIZ MR0, $\#5.0$ ; MR0 = 5.0 (0x40A00000)                                                                     |                           |                  |                 |                      |  |  |  |  |
| -           | MF32TOI16                                                  | MR1, MR0                                                                                                         |                           |                  | (MR0) = 0x0005  |                      |  |  |  |  |
|             |                                                            |                                                                                                                  |                           | -                | nsion of MR1(1  | $5) = 0 \times 0000$ |  |  |  |  |
|             | MMOVIZ<br>MF32TOI16                                        | MR2, #-5.0<br>MR3, MR2                                                                                           |                           | = -5.0 (0xC      | (MR2) = -5 (0x) | ר מיזיי              |  |  |  |  |
|             | MI 5210110                                                 | MCS, MCZ                                                                                                         |                           |                  | nsion of MR3(1  |                      |  |  |  |  |
| See also    | MF32TOUI<br>MF32TOUI<br>MI16TOF32<br>MI16TOF32<br>MUI16TOF | 6R MRa, MR<br>16 MRa, MR<br>16R MRa, M<br>2 MRa, MRb<br>2 MRa, men<br>32 MRa, mei<br>32 MRa, MR                  | b<br>b<br>Rb<br>16<br>m16 |                  |                 |                      |  |  |  |  |

# MF32TOI16R MRa, MRb Convert 32-Bit Floating-Point Value to 16-Bit Integer and Round

| oporanao    | MRa CLA                                          | floating-point de                                                                                 | estination register (M | R0 to MR3)         |                    |       |  |  |  |
|-------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------|------------------------|--------------------|--------------------|-------|--|--|--|
|             |                                                  | 01                                                                                                | ource register (MR0 1  | ,                  |                    |       |  |  |  |
|             |                                                  | noating-point sc                                                                                  |                        |                    |                    |       |  |  |  |
| Opcode      | LSW: 0000 0000 0000 1                            | bbaa                                                                                              |                        |                    |                    |       |  |  |  |
|             | MSW: 0111 1110 0110                              | 0000                                                                                              |                        |                    |                    |       |  |  |  |
| Description | Convert the 32-bit floa<br>even value. The resul |                                                                                                   |                        | 16-bit integer and | d round to the nea | arest |  |  |  |
|             | MRa(15:0) = F32TOI16:<br>MRa(31:16) = sign ex    | . ,                                                                                               | Ra(15);                |                    |                    |       |  |  |  |
| Flags       | This instruction does                            | not affect any                                                                                    | flags:                 |                    |                    |       |  |  |  |
|             | Flag TF                                          | ZF                                                                                                | NF                     | LUF                | LVF                |       |  |  |  |
|             | Modified No                                      | No                                                                                                | No                     | No                 | No                 |       |  |  |  |
| Pipeline    | This is a single-cycle                           | instruction.                                                                                      |                        |                    |                    |       |  |  |  |
| Example     | MMOVIZ MR0, #0x3FD9                              | ; MR0(31:1                                                                                        | 6) = 0x3FD9            |                    |                    |       |  |  |  |
|             | MMOVXI MR0, #0x999A                              |                                                                                                   |                        |                    |                    |       |  |  |  |
|             | MF32TOI16R MR1, MR0                              | ; MRO = 1.7 (0x3FD9999A)<br>MF32TOI16R MR1, MRO   ; MR1(15:0) = MF32TOI16round (MRO) = 2 (0x0002) |                        |                    |                    |       |  |  |  |
|             |                                                  |                                                                                                   | ,                      | sion of MR1(15)    | ,                  |       |  |  |  |
|             | MMOVF32 MR2, #-1.7                               |                                                                                                   | .7 (0xBFD9999A)        |                    |                    |       |  |  |  |
|             | MF32TOI16R MR3, MR2                              |                                                                                                   | ,                      | and $(MR2) = -2$   | . ,                |       |  |  |  |
|             |                                                  | ; MR3(31:1)                                                                                       | b) = Sign exten:       | sion of MR2(15)    | = UXFFFF           |       |  |  |  |
| See also    | MF32TOI16 MRa, MR                                | lb                                                                                                |                        |                    |                    |       |  |  |  |
|             | MF32TOUI16 MRa, M                                |                                                                                                   |                        |                    |                    |       |  |  |  |
|             | MF32TOUI16R MRa,                                 |                                                                                                   |                        |                    |                    |       |  |  |  |
|             | MI16TOF32 MRa, MR                                |                                                                                                   |                        |                    |                    |       |  |  |  |
|             | MI16TOF32 MRa, me<br>MUI16TOF32 MRa, m           |                                                                                                   |                        |                    |                    |       |  |  |  |
|             | MUI16TOF32 MRa, M                                |                                                                                                   |                        |                    |                    |       |  |  |  |
|             |                                                  | -                                                                                                 |                        |                    |                    |       |  |  |  |



# MF32TOI32 MRa, MRb Convert 32-Bit Floating-Point Value to 32-Bit Integer

| Operands    |                                                                                                                                                                                                                                                                                      |                                  |                                  |                                     |                  |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------|-------------------------------------|------------------|--|--|--|--|--|
|             | MRa                                                                                                                                                                                                                                                                                  | CLA floating-point des           | stination register (N            | /IR0 to MR3)                        |                  |  |  |  |  |  |
|             | MRb                                                                                                                                                                                                                                                                                  | CLA floating-point sou           | urce register (MR0               | to MR3)                             |                  |  |  |  |  |  |
| Opcode      | LSW: 0000 0000<br>MSW: 0111 1101                                                                                                                                                                                                                                                     |                                  |                                  |                                     |                  |  |  |  |  |  |
| Description | Convert the 32-<br>Store the result<br>MRa = F32TOI32                                                                                                                                                                                                                                | -                                | ie in MRb to a                   | 32-bit integer val                  | ue and truncate. |  |  |  |  |  |
| Flags       | This instruction does not affect any flags:                                                                                                                                                                                                                                          |                                  |                                  |                                     |                  |  |  |  |  |  |
|             | FlagTFModifiedNo                                                                                                                                                                                                                                                                     | ZF<br>No                         | NF<br>No                         | LUF<br>No                           | LVF<br>No        |  |  |  |  |  |
| Pipeline    | This is a single-                                                                                                                                                                                                                                                                    | cycle instruction.               |                                  |                                     |                  |  |  |  |  |  |
| Example 1   | MF32TOI32 MR3,                                                                                                                                                                                                                                                                       | #-11204005.0 ; M                 | R3 = MF32TOI32<br>R0 = -11204005 | (MR2) = 11204005<br>.0 (0xCB2AF5A5) |                  |  |  |  |  |  |
| Example 2   | <pre>MF32TOI32 MR1, MR0 ; MR1 = MF32TOI32(MR0) = -11204005 (0xFF550A5B) ; Given X, M and B are IQ24 numbers: ; X = IQ24(+2.5) = 0x02800000 ; M = IQ24(+1.5) = 0x01800000 ; B = IQ24(-0.5) = 0xFF800000 ; ; Calculate Y = X * M + B ; ; Convert M, X and B from IQ24 to float ;</pre> |                                  |                                  |                                     |                  |  |  |  |  |  |
| See also    | MF32TOUI32 N<br>MI32TOF32 MR<br>MI32TOF32 MR<br>MUI32TOF32 N<br>MUI32TOF32 N                                                                                                                                                                                                         | ta, MRb<br>ta, mem32<br>IRa, MRb |                                  |                                     |                  |  |  |  |  |  |

# MF32TOUI16 MRa, MRb Convert 32-Bit Floating-Point Value to 16-bit Unsigned Integer

| oporando    | MRa                                                        | CLA flo                                                                                                                                                                                                                            | pating-point des | tination register (M                               | R0 to MR3)              |       |  |  |  |  |
|-------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------------------------------------|-------------------------|-------|--|--|--|--|
|             | MRb                                                        |                                                                                                                                                                                                                                    | 0.1              | rce register (MR0 t                                | ,                       |       |  |  |  |  |
|             |                                                            | 02/11                                                                                                                                                                                                                              |                  |                                                    |                         |       |  |  |  |  |
| Opcode      |                                                            | 0000 0000 bb<br>110 1010 00                                                                                                                                                                                                        |                  |                                                    |                         |       |  |  |  |  |
| Description | truncate to a                                              | Convert the 32-bit floating point value in MRb to an unsigned 16-bit integer value and truncate to zero. The result will be stored in MRa. To instead round the integer to the nearest even value use the MF32TOUI16R instruction. |                  |                                                    |                         |       |  |  |  |  |
|             | MRa(15:0) =<br>MRa(31:16)                                  | = F32TOUI16()<br>= 0x0000;                                                                                                                                                                                                         | MRb);            |                                                    |                         |       |  |  |  |  |
| Flags       | This instruction does not affect any flags:                |                                                                                                                                                                                                                                    |                  |                                                    |                         |       |  |  |  |  |
|             | Flag                                                       | TF                                                                                                                                                                                                                                 | ZF               | NF                                                 | LUF                     | LVF   |  |  |  |  |
|             | Modified                                                   | No                                                                                                                                                                                                                                 | No               | No                                                 | No                      | No    |  |  |  |  |
| Pipeline    | This is a sir                                              | ngle-cycle ins                                                                                                                                                                                                                     | struction.       |                                                    |                         |       |  |  |  |  |
| Example     | MMOVIZ<br>MF32TOUI16                                       | MMOVIZ MR0, #9.0 ; MR0 = 9.0 (0x41100000)<br>MF32TOUI16 MR1, MR0 ; MR1(15:0) = MF32TOUI16(MR0) = 9 (0x0009)<br>; MR1(31:16) = 0x0000                                                                                               |                  |                                                    |                         |       |  |  |  |  |
|             | MMOVIZ<br>MF32TOUI16                                       | MR2, #-9.0<br>MR3, MR2                                                                                                                                                                                                             | ; MR3(15         | -9.0 (0xC110000<br>:0) = MF32TOUI<br>:16) = 0x0000 | 00)<br>L6(MR2) = 0 (0x) | 0000) |  |  |  |  |
| See also    | MF32TOUI<br>MF32TOUI<br>MI16TOF32<br>MI16TOF32<br>MU16TOF3 | MRa, MRb<br>16 MRa, MR<br>16R MRa, M<br>2 MRa, MRb<br>2 MRa, mem<br>32 MRa, mer<br>32 MRa, MR                                                                                                                                      | Rb<br>16<br>m16  |                                                    |                         |       |  |  |  |  |



# MF32TOUI16R MRa, MRb Convert 32-Bit Floating-Point Value to 16-bit Unsigned Integer and Round

| •••••       | MDa                                                       |                                                                                                                                                                                                                              | tion on a line of a set                               | tingtion register (NA                                                 |                                |                 |  |  |  |  |  |
|-------------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------|--------------------------------|-----------------|--|--|--|--|--|
|             | MRa                                                       |                                                                                                                                                                                                                              | 0.                                                    | tination register (M                                                  | ,                              |                 |  |  |  |  |  |
|             | MRb                                                       | CLA floa                                                                                                                                                                                                                     | ting-point sour                                       | rce register (MR0 t                                                   | to MR3)                        |                 |  |  |  |  |  |
| Opcode      |                                                           | 000 0000 bbaa<br>110 1100 0000                                                                                                                                                                                               |                                                       |                                                                       |                                |                 |  |  |  |  |  |
| Description | the closest e                                             | Convert the 32-bit floating-point value in MRb to an unsigned 16-bit integer and round to the closest even value. The result will be stored in MRa. To instead truncate the converted value, use the MF32TOUI16 instruction. |                                                       |                                                                       |                                |                 |  |  |  |  |  |
|             | . ,                                                       | <pre>MRa(15:0) = MF32TOUI16round(MRb);<br/>MRa(31:16) = 0x0000;</pre>                                                                                                                                                        |                                                       |                                                                       |                                |                 |  |  |  |  |  |
| Flags       | This instruct                                             | tion does not a                                                                                                                                                                                                              | affect any f                                          | lags:                                                                 |                                |                 |  |  |  |  |  |
|             | Flag                                                      | TF                                                                                                                                                                                                                           | ZF                                                    | NF                                                                    | LUF                            | LVF             |  |  |  |  |  |
|             | Modified                                                  | No                                                                                                                                                                                                                           | No                                                    | No                                                                    | No                             | No              |  |  |  |  |  |
| Pipeline    | This is a sin                                             | gle-cycle instr                                                                                                                                                                                                              | uction.                                               |                                                                       |                                |                 |  |  |  |  |  |
| Example     | MMOVIZ<br>MMOVXI<br>MF32TOUI16R<br>MMOVF32<br>MF32TOUI16R | MR2, #-10.8                                                                                                                                                                                                                  | CD ; MR0<br>; MR1<br>; MR1<br>; MR2<br>; MR2<br>; MR3 | (15:0) = MF327<br>(31:16) = 0x00<br>(= -10.8 (0x02)<br>(15:0) = MF327 | xCl2CCCCD)<br>FOUI16round(MR2) | ) = 11 (0x000B) |  |  |  |  |  |
| See also    | MF32TOUI1<br>MI16TOF32<br>MI16TOF32<br>MUI16TOF3          | R MRa, MRb<br>6 MRa, MRb                                                                                                                                                                                                     | 6                                                     | (31:16) = 0x00                                                        |                                |                 |  |  |  |  |  |



# MF32TOUI32 MRa, MRb Convert 32-Bit Floating-Point Value to 32-Bit Unsigned Integer

| • • • • • • • • • • • • • • • • • • • • |                                              |                                                                                                           |                        |                     |                            |     |  |  |  |
|-----------------------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------|---------------------|----------------------------|-----|--|--|--|
|                                         | MRa                                          | CLA flo                                                                                                   | ating-point dest       | ination register (N | IR0 to MR3)                |     |  |  |  |
|                                         | MRb                                          | CLA flo                                                                                                   | ating-point sour       | ce register (MR0    | to MR3)                    |     |  |  |  |
| Opcode                                  |                                              | 0000 0000 bba<br>101 1010 000                                                                             |                        |                     |                            |     |  |  |  |
| Description                             |                                              | Convert the 32-bit floating-point value in MRb to an unsigned 32-bit integer and store the result in MRa. |                        |                     |                            |     |  |  |  |
|                                         | MRa = F32TC                                  | )UI32(MRb);                                                                                               |                        |                     |                            |     |  |  |  |
| Flags                                   | This instruc                                 | tion does not                                                                                             | affect any fl          | ags:                |                            |     |  |  |  |
|                                         | Flag                                         | TF                                                                                                        | ZF                     | NF                  | LUF                        | LVF |  |  |  |
|                                         | Modified                                     | No                                                                                                        | No                     | No                  | No                         | No  |  |  |  |
| Pipeline                                | This is a sir                                | ngle-cycle ins                                                                                            | truction.              |                     |                            |     |  |  |  |
| Example                                 | MMOVIZ<br>MF32TOUI32<br>MMOVIZ<br>MF32TOUI32 | MR0, #12.5<br>MR0, MR0<br>MR1, #-6.5<br>MR2, MR1                                                          | ; MR0 = M<br>; MR1 = - | 6.5 (0xC0D000       | $0) = 12 (0 \times 00000)$ |     |  |  |  |
| See also                                | MI32TOF32<br>MI32TOF32<br>MUI32TOF3          | 2 MRa, MRb<br>2 MRa, MRb<br>2 MRa, mem3<br>32 MRa, MRI<br>32 MRa, mer                                     | C                      |                     |                            |     |  |  |  |



# MFRACF32 MRa, MRb Fractional Portion of a 32-Bit Floating-Point Value

| Operatius   |                                                          |                        |                  |                                    |                         |          |  |  |  |
|-------------|----------------------------------------------------------|------------------------|------------------|------------------------------------|-------------------------|----------|--|--|--|
|             | MRa CLA floating-point destination register (MR0 to MR3) |                        |                  |                                    |                         |          |  |  |  |
|             | MRb CLA floating-point source register (MR0 to MR3)      |                        |                  |                                    |                         |          |  |  |  |
| Opcode      |                                                          | 0000 0000<br>1110 0000 |                  |                                    |                         |          |  |  |  |
| Description | Returns ir                                               | n MRa the fi           | ractional portio | n of the 32-bit fl                 | oating-point valu       | e in MRb |  |  |  |
| Flags       | This instruction does not affect any flags:              |                        |                  |                                    |                         |          |  |  |  |
|             | Flag                                                     | TF                     | ZF               | NF                                 | LUF                     | LVF      |  |  |  |
|             | Modified                                                 | No                     | No               | No                                 | No                      | No       |  |  |  |
| Pipeline    | This is a s                                              | single-cycle           | instruction.     |                                    |                         |          |  |  |  |
| Example     | MMOVIZ<br>MFRACF32                                       | MR2, #19.6<br>MR3, MR2 |                  | .625 (0x419D000<br>RACF32(MR2) = 0 | )0)<br>).625 (0x3F20000 | 00)0)    |  |  |  |
| See also    |                                                          |                        |                  |                                    |                         |          |  |  |  |



# MI16TOF32 MRa, MRb Convert 16-Bit Integer to 32-Bit Floating-Point Value

| operands    |                                             |                        |                |                         |                   |                   |    |  |  |  |
|-------------|---------------------------------------------|------------------------|----------------|-------------------------|-------------------|-------------------|----|--|--|--|
|             | MRa                                         | CLA                    | floating-point | destination register (M | R0 to MR3)        |                   |    |  |  |  |
|             | MRb                                         | CLA                    | floating-point | source register (MR0 t  | o MR3)            |                   |    |  |  |  |
|             |                                             |                        |                |                         |                   |                   |    |  |  |  |
| Opcode      | LSW: 0000                                   | 0000 0000 k            | baa            |                         |                   |                   |    |  |  |  |
|             | MSW: 0111                                   | 1110 1000 0            | 1000           |                         |                   |                   |    |  |  |  |
| Description | Convert the<br>result in M                  |                        | ied integer    | in MRb to a 32-bit      | floating point va | alue and store th | ıe |  |  |  |
|             |                                             | TOF32(MRb);            |                |                         |                   |                   |    |  |  |  |
| Flags       | This instruction does not affect any flags: |                        |                |                         |                   |                   |    |  |  |  |
|             | Flag                                        | TF                     | ZF             | NF                      | LUF               | LVF               |    |  |  |  |
|             | Modified                                    | No                     | No             | No                      | No                | No                |    |  |  |  |
| Pipeline    | This is a si                                | ngle-cycle i           | nstruction.    |                         |                   |                   |    |  |  |  |
| Example     | MMOVIZ                                      | MR0, #0x0              | 1000 ; !       | MR0(31:16) = 0.0        | (0x0000)          |                   |    |  |  |  |
|             | MMOVXI                                      | MR0, #0x0              |                | MR0(15:0) = 4.0 (0      |                   |                   |    |  |  |  |
|             | MI16TOF32                                   | MR1, MR0               | ; ]            | MR1 = MI16TOF32 (N      | 4R0) = 4.0 (0x4)  | )800000)          |    |  |  |  |
|             | MMOVIZ                                      | MR2, #0x0              | ; 0000         | MR2(31:16) = 0.0        | (0x0000)          |                   |    |  |  |  |
|             | MMOVXI                                      | MR2, #0xF              |                | MR2(15:0) = -4.0        | , ,               |                   |    |  |  |  |
|             | MI16TOF32<br>MSTOP                          | MR3, MR2               | ;              | MR3 = MI16TOF32 (N      | 4R2) = -4.0 (0x)  | 20800000)         |    |  |  |  |
| See also    | MF32TOI1                                    | 6 MRa, MR              | b              |                         |                   |                   |    |  |  |  |
|             | MF32TOI1                                    | 6R MRa, M              | Rb             |                         |                   |                   |    |  |  |  |
|             |                                             | 16 MRa, M              |                |                         |                   |                   |    |  |  |  |
|             |                                             | 16R MRa, I             |                |                         |                   |                   |    |  |  |  |
|             |                                             | 2 MRa, mei             |                |                         |                   |                   |    |  |  |  |
|             |                                             | 32 MRa, m<br>32 MRa, M |                |                         |                   |                   |    |  |  |  |
|             |                                             |                        |                |                         |                   |                   |    |  |  |  |



# MI16TOF32 MRa, mem16 Convert 16-Bit Integer to 32-Bit Floating-Point Value

| oporanao    |                                                       |                                                                                                                                    |                                    |                                     |             |     |  |  |  |  |
|-------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-------------------------------------|-------------|-----|--|--|--|--|
|             | MRa                                                   | CL                                                                                                                                 | A floating-point de                | stination register (M               | IR0 to MR3) |     |  |  |  |  |
|             | mem16                                                 | 16                                                                                                                                 | -bit source memor                  | y location to be conv               | verted      |     |  |  |  |  |
| Opcode      | LSW: mmmm<br>MSW: 0111                                | mmmm mmmm<br>0101 00aa                                                                                                             |                                    |                                     |             |     |  |  |  |  |
| Description |                                                       | Convert the 16-bit signed integer indicated by the mem16 pointer to a 32-bit floating-<br>point value and store the result in MRa. |                                    |                                     |             |     |  |  |  |  |
|             | MRa = MI16                                            | <pre>MRa = MI16TOF32[mem16];</pre>                                                                                                 |                                    |                                     |             |     |  |  |  |  |
| Flags       | This instruction does not affect any flags:           |                                                                                                                                    |                                    |                                     |             |     |  |  |  |  |
|             | Flag                                                  | TF                                                                                                                                 | ZF                                 | NF                                  | LUF         | LVF |  |  |  |  |
|             | Modified                                              | No                                                                                                                                 | No                                 | No                                  | No          | No  |  |  |  |  |
| Pipeline    | This is a s                                           | ingle-cycle                                                                                                                        | e instruction:                     |                                     |             |     |  |  |  |  |
| Example     |                                                       | ; Assume $A = 4 (0x0004)$<br>; $B = -4 (0xFFFC)$                                                                                   |                                    |                                     |             |     |  |  |  |  |
|             |                                                       |                                                                                                                                    |                                    | L6TOF32(A) = 4.0<br>L6TOF32(B) = -4 |             |     |  |  |  |  |
| See also    | MF32TOI<br>MF32TOU<br>MF32TOU<br>MI16TOF3<br>MUI16TOI | 16 MRa, M<br>16R MRa, 1<br>1116 MRa, 1<br>1116R MRa<br>32 MRa, M<br>F32 MRa, 1<br>F32 MRa, 1                                       | MRb<br>MRb<br>, MRb<br>Rb<br>mem16 |                                     |             |     |  |  |  |  |



# MI32TOF32 MRa, mem32 Convert 32-Bit Integer to 32-Bit Floating-Point Value

### Operands

| Operands    |                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                       |                    |                       |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--------------------|-----------------------|--|--|--|--|--|
|             | MRa                                                                                        | CLA floating-po                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | oint destination register (M                                          | R0 to MR3)         |                       |  |  |  |  |  |
|             | mem32                                                                                      | 32-bit memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | source for the MMOV32 o                                               | peration.          |                       |  |  |  |  |  |
| Opcode      |                                                                                            | nmm mmmm mmmm<br>100 01aa addr                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                       |                    |                       |  |  |  |  |  |
| Description | store the res                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | er indicated by mem                                                   | 32 to a 32-bit flo | ating point value and |  |  |  |  |  |
| Flags       | This instruction does not affect any flags:                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                       |                    |                       |  |  |  |  |  |
|             | Flag                                                                                       | TF ZF                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | NF                                                                    | LUF                | LVF                   |  |  |  |  |  |
|             | Modified                                                                                   | No No                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | No                                                                    | No                 | No                    |  |  |  |  |  |
| Pipeline    | This is a sin                                                                              | gle-cycle instructio                                                                                                                                                                                                                                                                                                                                                                                                                                                              | n.                                                                    |                    |                       |  |  |  |  |  |
| Example     | <pre>; X = IQ24(<br/>; M = IQ24(<br/>; B = IQ24(<br/>;<br/>; Calculate<br/>;</pre>         | ; Calculate Y = X * M + B<br>;<br>; Convert M, X and B from IQ24 to float                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                       |                    |                       |  |  |  |  |  |
|             | MI32TOF3<br>MI32TOF3<br>MMPYF32<br>MMPYF32<br>MMPYF32<br>MMPYF32<br>MADDF32<br>; Convert Y | _ClalTask3:<br>MI32TOF32 MR0, @_M ; MR0 = 0x4BC00000<br>MI32TOF32 MR1, @_X ; MR1 = 0x4C200000<br>MI32TOF32 MR2, @_B ; MR2 = 0xCB000000<br>MMPYF32 MR0, MR0, #0x3380 ; M = 1/(1*2^24) * iqm = 1.5 (0x3FC00000)<br>MMPYF32 MR1, MR1, #0x3380 ; X = 1/(1*2^24) * iqx = 2.5 (0x40200000)<br>MMPYF32 MR2, MR2, #0x3380 ; B = 1/(1*2^24) * iqb =5 (0xBF000000)<br>MMPYF32 MR3, MR0, MR1 ; M*X<br>MADDF32 MR2, MR2, MR3 ; Y=MX+B = 3.25 (0x40500000)<br>; Convert Y from float32 to IQ24 |                                                                       |                    |                       |  |  |  |  |  |
|             |                                                                                            | MR2, MR2, #0x4B80<br>2 MR2, MR2<br>_Y, MR2                                                                                                                                                                                                                                                                                                                                                                                                                                        | ; Y * 1*2^24<br>; IQ24(Y) = 0x0340<br>; store result<br>; end of task | 00000              |                       |  |  |  |  |  |
| See also    | MI32TOF32                                                                                  | 2 MRa, MRb                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                       |                    |                       |  |  |  |  |  |

MUI32TOF32 MRa, mem32



# MI32TOF32 MRa, MRb Convert 32-Bit Integer to 32-Bit Floating-Point Value

| Operatius   |                                                                                                                                                                                                                                |                                                                                                        |                     |                         |            |     |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------|-------------------------|------------|-----|--|--|--|--|
|             | MRa                                                                                                                                                                                                                            | CL                                                                                                     | A floating-point de | estination register (MI | R0 to MR3) |     |  |  |  |  |
|             | MRb                                                                                                                                                                                                                            | CL                                                                                                     | A floating-point so | ource register (MR0 to  | o MR3)     |     |  |  |  |  |
| Opcode      |                                                                                                                                                                                                                                | LSW: 0000 0000 bbaa<br>MSW: 0111 1101 1000 0000                                                        |                     |                         |            |     |  |  |  |  |
| Description |                                                                                                                                                                                                                                | Convert the signed 32-bit integer in MRb to a 32-bit floating-point value and store the result in MRa. |                     |                         |            |     |  |  |  |  |
|             | MRa = MI32                                                                                                                                                                                                                     | 2TOF32(MRb                                                                                             | );                  |                         |            |     |  |  |  |  |
| Flags       | This instru                                                                                                                                                                                                                    | iction does                                                                                            | not affect any      | flags:                  |            |     |  |  |  |  |
|             | Flag                                                                                                                                                                                                                           | TF                                                                                                     | ZF                  | NF                      | LUF        | LVF |  |  |  |  |
|             | Modified                                                                                                                                                                                                                       | No                                                                                                     | No                  | No                      | No         | No  |  |  |  |  |
| Pipeline    | This is a s                                                                                                                                                                                                                    | ingle-cycle                                                                                            | instruction.        |                         |            |     |  |  |  |  |
| Example     | <pre>; Example1: ; MMOVIZ MR2, #0x1111 ; MR2(31:16) = 4369 (0x1111) MMOVXI MR2, #0x1111 ; MR2(15:0) = 4369 (0x1111) ; MR2 = +286331153 (0x1111111) MI32TOF32 MR3, MR2 ; MR3 = MI32TOF32 (MR2) = 286331153.0 (0x4D888888)</pre> |                                                                                                        |                     |                         |            |     |  |  |  |  |
| See also    | MF32TOU<br>MI32TOF3<br>MUI32TOI                                                                                                                                                                                                | 32 MRa, M<br>II32 MRa, I<br>32 MRa, m<br>F32 MRa, I<br>F32 MRa, I                                      | MRb<br>em32<br>MRb  |                         |            |     |  |  |  |  |

# MLSL32 MRa, #SHIFT Logical Shift Left

| Operands    |                                                                                                                                    |                                                                                                                                  |                                                                      |                       |                   |                       |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------|-------------------|-----------------------|--|--|--|--|
|             | MRa                                                                                                                                | CLA flo                                                                                                                          | pating-point so                                                      | urce/destination regi | ster (MR0 to MR3) |                       |  |  |  |  |
|             | #SHIFT                                                                                                                             | Numbe                                                                                                                            | er of bits to shi                                                    | ft (1 to 32)          |                   |                       |  |  |  |  |
| Opcode      | LSW: 0000 00<br>MSW: 0111 10                                                                                                       |                                                                                                                                  |                                                                      |                       |                   |                       |  |  |  |  |
| Description | 32.                                                                                                                                |                                                                                                                                  | -                                                                    |                       |                   | r of bits can be 1 to |  |  |  |  |
| Flore       | MARa(31:0) = Logical Shift Left(MARa(31:0) by #SHIFT bits);<br>This instruction modifies the following flags in the MSTF register: |                                                                                                                                  |                                                                      |                       |                   |                       |  |  |  |  |
| Flags       |                                                                                                                                    | TF                                                                                                                               | ZF                                                                   | NF                    | LUF               | LVF                   |  |  |  |  |
|             |                                                                                                                                    | No                                                                                                                               | Yes                                                                  | Yes                   | No                | No                    |  |  |  |  |
|             | The MSTF re<br>NF = MRa(31)<br>ZF = 0;<br>if(MRa(31:0)                                                                             | ;                                                                                                                                |                                                                      | ed based on the       | integer results o | f the operation.      |  |  |  |  |
| Pipeline    | This is a sing                                                                                                                     | gle-cycle ins                                                                                                                    | struction.                                                           |                       |                   |                       |  |  |  |  |
| Example     | ; b2 =<br>;<br>; Calculate:<br>; m2 =<br>; x2 =                                                                                    | <pre>: (int32)64 : (int32)-1. : m2*2 : x2*4 : b2*8 :0, @_m2 :1, @_x2 :2, @_b2 :0, #1 :1, #2 :2, #3 m2, MR0 x2, MR1 b2, MR2</pre> | ; MRO = 32<br>; MR1 = 64<br>; MR2 = -12<br>; MRO = 64<br>; MR1 = 256 |                       |                   |                       |  |  |  |  |
| See also    | MADD32 MF<br>MASR32 MF<br>MAND32 MF<br>MLSR32 MR<br>MOR32 MR<br>MXOR32 MF<br>MSUB32 MF                                             | Ra, #SHIFT<br>Ra, MRb, M<br>a, #SHIFT<br>a, MRb, MR<br>Ra, MRb, M                                                                | Rc<br>c<br>Rc                                                        |                       |                   |                       |  |  |  |  |

# MLSR32 MRa, #SHIFT Logical Shift Right

## Operands

| oporanao    | MRa<br>#SHIFT                                                                    | CLA floating-point so<br>Number of bits to sh                              | ource/destination reg<br>ift (1 to 32)        | ister (MR0 to MR3)                      |                                                                            |
|-------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------------|----------------------------------------------------------------------------|
| Opcode      | LSW: 0000 000<br>MSW: 0111 101                                                   |                                                                            |                                               |                                         |                                                                            |
| Description | 32. Unlike the<br>sign bit. Every<br>vacant bit-pos                              | arithmetic shift (MAS<br>bit in the operand is<br>itions are filled in wit | R32), the logica<br>moved the spec<br>n zeros | l shift does not p<br>ified number of l | per of bits can be 1 to<br>preserve the number's<br>pit positions, and the |
|             |                                                                                  | Logical Shift Right                                                        | _                                             |                                         |                                                                            |
| Flags       | This instructio                                                                  | n modifies the follow<br>F ZF                                              | ng flags in the N<br>NF                       | ISTF register:<br>LUF                   | LVF                                                                        |
|             |                                                                                  | lo Yes                                                                     | Yes                                           | No                                      | No                                                                         |
| Pipeline    |                                                                                  | e-cycle instruction.                                                       |                                               |                                         |                                                                            |
|             | if(MRa(31:0)                                                                     | $== 0) \{ ZF = 1; \}$                                                      |                                               |                                         |                                                                            |
| •           | This is a single                                                                 | e-cycle instruction.                                                       |                                               |                                         |                                                                            |
| Example     | ; Illustrate                                                                     | the difference betw                                                        | een MASR32 and M                              | MLSR32                                  |                                                                            |
|             | MMOVIZ MR0, #<br>MMOVXI MR0, #                                                   |                                                                            | AAAA5555                                      |                                         |                                                                            |
|             | MMOV32 MR1, M                                                                    |                                                                            | AAAA5555                                      |                                         |                                                                            |
|             | MMOV32 MR2, M                                                                    | R0 ; $MR2 = 0x$                                                            | AAAA5555                                      |                                         |                                                                            |
|             | MASR32 MR1, #                                                                    |                                                                            |                                               |                                         |                                                                            |
|             | MLSR32 MR2, #                                                                    | 1 	 ; MR2 = 0x                                                             | 55552AAA                                      |                                         |                                                                            |
|             | MASR32 MR1, #                                                                    |                                                                            |                                               |                                         |                                                                            |
|             | MLSR32 MR2, #                                                                    | 1 	 ; MR2 = 0x                                                             | 2AAA9555                                      |                                         |                                                                            |
|             | MASR32 MR1, #                                                                    |                                                                            |                                               |                                         |                                                                            |
|             | MLSR32 MR2, #                                                                    | 6 ; $MR2 = 0x$                                                             | 00AAAA55                                      |                                         |                                                                            |
| See also    | MADD32 MRa<br>MASR32 MRa<br>MAND32 MRa<br>MLSL32 MRa<br>MOR32 MRa,<br>MXOR32 MRa | a, #SHIFT<br>a, MRb, MRc<br>, #SHIFT<br>MRb, MRc                           |                                               |                                         |                                                                            |

MSUB32 MRa, MRb, MRc



# MMACF32 MR3, MR2, MRd, MRe, MRf ||MMOV32 MRa, mem32 32-Bit Floating-Point Multiply and Accumulate with Parallel Move

| Operands     |                                                                                                                                                                           |             |                             |                                                |                                     |                                   |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------|------------------------------------------------|-------------------------------------|-----------------------------------|--|--|
|              | MR3                                                                                                                                                                       | floa        | ating-point destinat        | ion/source register N                          | /IR3 for the add oper               | ation                             |  |  |
|              | MR2 CLA floating-point source register MR2 for the add operation                                                                                                          |             |                             |                                                |                                     |                                   |  |  |
|              | MRd                                                                                                                                                                       |             |                             | stination register (MI<br>ame register as MRa  | R0 to MR3) for the m<br>a           | ultiply operation                 |  |  |
|              | MRe                                                                                                                                                                       | CL          | A floating-point sou        | urce register (MR0 to                          | o MR3) for the multip               | oly operation                     |  |  |
|              | MRf                                                                                                                                                                       | CL          | A floating-point sou        | urce register (MR0 to                          | o MR3) for the multip               | ly operation                      |  |  |
|              | MRa                                                                                                                                                                       |             |                             | stination register for<br>or the same register | the MMOV32 operat                   | ion (MR0 to MR3).                 |  |  |
|              | mem32                                                                                                                                                                     | 32-         | -bit source for the I       | MMOV32 operation                               |                                     |                                   |  |  |
| Opcode       | LSW: mmmm n<br>MSW: 0011 f                                                                                                                                                |             |                             |                                                |                                     |                                   |  |  |
| Description  | to memory.                                                                                                                                                                | The dest    |                             | for the MMOV3                                  | nt registers and<br>2 cannot be the | move from register<br>same as the |  |  |
|              | MR3 = MR3 +<br>MRd = MRe *<br>MRa = [mem3                                                                                                                                 | MRf;        |                             |                                                |                                     |                                   |  |  |
| Restrictions |                                                                                                                                                                           |             |                             |                                                | MMOV32 must register as MRd         | be unique. That is,               |  |  |
| Flags        | This instruc                                                                                                                                                              | tion modi   | fies the followir           | ng flags in the M                              | STF register:                       |                                   |  |  |
| -            | Flag                                                                                                                                                                      | TF          | ZF                          | NF                                             | LUF                                 | LVF                               |  |  |
|              | Modified                                                                                                                                                                  | No          | Yes                         | Yes                                            | Yes                                 | Yes                               |  |  |
|              |                                                                                                                                                                           | rogiotor fl | aga ara madific             | d oo followou                                  |                                     |                                   |  |  |
|              | The MSTF register flags are modified as follows:                                                                                                                          |             |                             |                                                |                                     |                                   |  |  |
|              | <ul> <li>LUF = 1 if MMACF32 (add or multiply) generates an underflow condition.</li> <li>LVF = 1 if MMACF32 (add or multiply) generates an overflow condition.</li> </ul> |             |                             |                                                |                                     |                                   |  |  |
|              | • LVF = 1                                                                                                                                                                 | IT MMAC     | F32 (add or mu              | ultiply) generates                             | s an overflow cor                   | idition.                          |  |  |
|              | NF = MRa(31)<br>ZF = 0;                                                                                                                                                   | .);         | F and ZF flags { ZF = 1; NF |                                                |                                     |                                   |  |  |
| Pipeline     | MMACF32                                                                                                                                                                   | and MMC     | 0V32 complete               | in a single cycle                              |                                     |                                   |  |  |



| ww | w.ti | .com |
|----|------|------|
|    |      |      |

| Example 1 | ; Perform 5 multiply and accumulat | e operations:                               |
|-----------|------------------------------------|---------------------------------------------|
|           | ;                                  |                                             |
|           | ; X and Y are 32-bit floating poin | t arrays                                    |
|           | ;                                  |                                             |
|           | ; 1st multiply: A = X0 * Y0        |                                             |
|           | ; 2nd multiply: B = X1 * Y1        |                                             |
|           | ; 3rd multiply: C = X2 * Y2        |                                             |
|           | ; 4th multiply: D = X3 * Y3        |                                             |
|           | ; 5th multiply: E = X3 * Y3        |                                             |
|           | ;                                  |                                             |
|           | ; Result = $A + B + C + D + E$     |                                             |
|           | ;                                  |                                             |
|           | _ClalTaskl:                        |                                             |
|           | MMOVI16 MAR0, #_X                  | ; MARO points to X array                    |
|           | MMOVI16 MAR1, #_Y                  | ; MAR1 points to Y array                    |
|           | MNOP                               | ; Delay for MAR0, MAR1 load                 |
|           | MNOP                               | ; Delay for MAR0, MAR1 load                 |
|           |                                    | ; < MAR0 valid                              |
|           | MMOV32 MR0, *MAR0[2]++             | ; MRO = XO, MARO += 2                       |
|           |                                    | ; < MAR1 valid                              |
|           | MMOV32 MR1, *MAR1[2]++             | ; MR1 = Y0, MAR1 += 2                       |
|           |                                    |                                             |
|           | MMPYF32 MR2, MR0, MR1              | ; MR2 = A = X0 * Y0                         |
|           | MMOV32 MR0, *MAR0[2]++             | ; In parallel MRO = X1, MARO += 2           |
|           | MMOV32 MR1, *MAR1[2]++             | ; MR1 = Y1, MAR1 += 2                       |
|           |                                    |                                             |
|           |                                    | ; MR3 = B = X1 * Y1                         |
|           | MMOV32 MR0, *MAR0[2]++             | ; In parallel MRO = X2, MARO += 2           |
|           | MMOV32 MR1, *MAR1[2]++             | ; MR1 = Y2, MAR2 += 2                       |
|           |                                    |                                             |
|           |                                    | ; MR3 = $A + B$ , MR2 = $C = X2 * Y2$       |
|           | MMOV32 MR0, *MAR0[2]++             |                                             |
|           | MMOV32 MR1, *MAR1[2]++             | ; MR1 = Y3 M                                |
|           |                                    |                                             |
|           |                                    | ; $MR3 = (A + B) + C$ , $MR2 = D = X3 * Y3$ |
|           |                                    | ; In parallel MRO = X4                      |
|           | MMOV32 MR1, *MAR1                  | ; MR1 = Y4                                  |
|           |                                    |                                             |
|           | MMPYF32 MR2, MR0, MR1              |                                             |
|           | MADDF32 MR3, MR3, MR2              | ; in parallel MR3 = $(A + B + C) + D$       |
|           | MADDF32 MR3, MR3, MR2              | ; MR3 = $(A + B + C + D) + E$               |
|           |                                    | ; Store the result                          |
|           | MSTOP                              | ; end of task                               |
|           | 10101                              | , chu or tabr                               |



```
Instruction Set
```

Example 2

|                                                                                                                 | + X1*B1 + X2*B2 + Y1*A1 + Y2*B2                                                                                                                                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ;                                                                                                               |                                                                                                                                                                                                                                                          |
| ; X2 = X                                                                                                        | <u>(1</u>                                                                                                                                                                                                                                                |
| ; X1 = X                                                                                                        | 02                                                                                                                                                                                                                                                       |
| ; Y2 = Y                                                                                                        | <i>(</i> 1 ; Y1 = sum                                                                                                                                                                                                                                    |
| ;                                                                                                               |                                                                                                                                                                                                                                                          |
| _ClaTask2:                                                                                                      |                                                                                                                                                                                                                                                          |
| MMOV32                                                                                                          | MR0, @_B2 ; MR0 = B2                                                                                                                                                                                                                                     |
| MMOV32                                                                                                          |                                                                                                                                                                                                                                                          |
| MMPYF32                                                                                                         |                                                                                                                                                                                                                                                          |
|                                                                                                                 | MR0, @_B1 ; MR0 = B1                                                                                                                                                                                                                                     |
|                                                                                                                 | MR1, @_X1 ; MR1 = X1, X2 = X1                                                                                                                                                                                                                            |
| MMPYF32                                                                                                         |                                                                                                                                                                                                                                                          |
|                                                                                                                 | MR0, @_B0 ; MR0 = B0                                                                                                                                                                                                                                     |
| MMOVD32                                                                                                         | MR1, @_X0 ; MR1 = X0, X1 = X0                                                                                                                                                                                                                            |
| MMOV32 MR                                                                                                       | 20, @_A2 M                                                                                                                                                                                                                                               |
| MOV32 MR1                                                                                                       | , @ Y2 ; MR1 = Y2                                                                                                                                                                                                                                        |
| MOV32 MR1                                                                                                       | l, @_Y2 ; MR1 = Y2                                                                                                                                                                                                                                       |
|                                                                                                                 | L, @_Y2 ; MR1 = Y2<br>D + X1*B1 + X2*B2, MR2 = Y2*A2                                                                                                                                                                                                     |
|                                                                                                                 |                                                                                                                                                                                                                                                          |
| ; MR3 = X0*B0<br>; MR0 = A1                                                                                     |                                                                                                                                                                                                                                                          |
| ; MR3 = X0*B0<br>; MR0 = A1                                                                                     | 0 + X1*B1 + X2*B2, MR2 = Y2*A2<br>MR3, MR2, MR2, MR1, MR0                                                                                                                                                                                                |
| ; MR3 = X0*B0<br>; MR0 = A1<br>MMACF32 M<br>   MMOV32 MR                                                        | D + X1*B1 + X2*B2, MR2 = Y2*A2<br>MR3, MR2, MR2, MR1, MR0<br>R0, @_A1                                                                                                                                                                                    |
| ; MR3 = X0*B0<br>; MR0 = A1<br>MMACF32 MR<br>   MMOV32 MR                                                       | D + X1*B1 + X2*B2, MR2 = Y2*A2<br>MR3, MR2, MR2, MR1, MR0<br>R0, @_A1<br>MR1.@ Y1 ; MR1 = Y1, Y2 = Y1                                                                                                                                                    |
| ; MR3 = X0*B0<br>; MR0 = A1<br>MMACF32 M<br>   MMOVJ32 MR<br>MMOVD32 M<br>MADDF32 M                             | D + X1*B1 + X2*B2, MR2 = Y2*A2<br>MR3, MR2, MR2, MR1, MR0<br>R0, @_A1<br>MR1,@_Y1 ; MR1 = Y1, Y2 = Y1<br>MR3, MR3, MR2 ; MR3 = Y2*A2 + X0*B0 + X1*B1 + X2*B2                                                                                             |
| ; MR3 = X0*B0<br>; MR0 = A1<br>MMACF32 M<br>   MMOVJ32 MR<br>MMOVD32 M<br>MADDF32 M<br>   MMPYF32 M             | D + X1*B1 + X2*B2, MR2 = Y2*A2<br>MR3, MR2, MR2, MR1, MR0<br>R0, @_A1<br>MR1,@_Y1 ; MR1 = Y1, Y2 = Y1<br>MR3, MR3, MR2 ; MR3 = Y2*A2 + X0*B0 + X1*B1 + X2*B2<br>MR2, MR1, MR0 ; MR2 = Y1*A1                                                              |
| <pre>; MR3 = X0*B0 ; MR0 = A1</pre>                                                                             | D + X1*B1 + X2*B2, MR2 = Y2*A2<br>MR3, MR2, MR2, MR1, MR0<br>R0, @_A1<br>MR1,@_Y1 ; MR1 = Y1, Y2 = Y1<br>MR3, MR3, MR2 ; MR3 = Y2*A2 + X0*B0 + X1*B1 + X2*B2<br>MR2, MR1, MR0 ; MR2 = Y1*A1<br>MR3, MR3, MR2 ; MR3 = Y1*A1 + Y2*A2 + X0*B0 + X1*B1 + X2* |
| ; MR3 = X0*B0<br>; MR0 = A1<br>MMACF32 M<br>   MMOV32 MR<br>MMOVD32 M<br>MADDF32 M<br>   MMPYF32 M<br>MADDF32 M | D + X1*B1 + X2*B2, MR2 = Y2*A2<br>MR3, MR2, MR2, MR1, MR0<br>R0, @_A1<br>MR1,@_Y1 ; MR1 = Y1, Y2 = Y1<br>MR3, MR3, MR2 ; MR3 = Y2*A2 + X0*B0 + X1*B1 + X2*B2<br>MR2, MR1, MR0 ; MR2 = Y1*A1                                                              |

See also

MMPYF32 MRa, MRb, MRc || MADDF32 MRd, MRe, MRf



## MMAXF32 MRa, MRb 32-Bit Floating-Point Maximum

| Operands    |                                                                                              |                                                                                           |                                                                                                                                                   |                                                     |                       |
|-------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------------|
|             | MRa                                                                                          | CLA floating-poir                                                                         | nt source/destination regis                                                                                                                       | ster (MR0 to MR3)                                   |                       |
|             | MRb                                                                                          | CLA floating-poir                                                                         | nt source register (MR0 to                                                                                                                        | ) MR3)                                              |                       |
| Opcode      | LSW: 0000 0000<br>MSW: 0111 1101                                                             |                                                                                           |                                                                                                                                                   |                                                     |                       |
| Description | if(MRa < MRb)                                                                                | MRa = MRb;                                                                                |                                                                                                                                                   |                                                     |                       |
|             | NaN output                                                                                   | will be converted                                                                         | n the MMAXF32 ope<br>I to infinity<br>e converted to positi                                                                                       |                                                     |                       |
| Flags       |                                                                                              | ·                                                                                         | owing flags in the MS                                                                                                                             |                                                     |                       |
|             | Flag TF                                                                                      |                                                                                           | NF                                                                                                                                                | LUF                                                 | LVF                   |
|             | Modified No                                                                                  | o Yes                                                                                     | Yes                                                                                                                                               | No                                                  | No                    |
|             | in the destinati                                                                             | <pre>on register.     {ZF=1; NF=0; }     {ZF=0; NF=0; }</pre>                             | ured on the result of                                                                                                                             | the operation, r                                    | not the result stored |
| Pipeline    | This is a single                                                                             | -cycle instruction                                                                        |                                                                                                                                                   |                                                     |                       |
| Example 1   | MMOVIZ MR1,<br>MMOVIZ MR2,<br>MMAXF32 MR2,<br>MMAXF32 MR1,                                   | #-2.0 ; MR1 = -2<br>#-1.5 ; MR2 = -1<br>MR1 ; MR2 = -1<br>MR2 ; MR1 = -1<br>MR0 ; MR2 = 5 | 5.0 (0x40A00000)<br>2.0 (0xC0000000)<br>1.5 (0xBFC00000)<br>1.5, ZF = NF = 0<br>1.5, ZF = 0, NF = 1<br>5.0, ZF = 0, NF = 1<br>5.0, ZF = 1, NF = 0 |                                                     |                       |
| Example 2   | ; Find the max<br>; and store it<br>;<br>ClalTask1:<br>MMOVI16 M<br>MUI16TOF32 M<br>MNOP<br> | rimum value in ar<br>: in Result<br>MAR1,#_X                                              | ; Start address<br>; Length of the a:<br>; delay for MAR1 ;<br>; delay for MAR1 ;                                                                 | load<br>load<br>ent<br>MR2)<br>ounter<br>for MBCNDD |                       |
| See also    | MCMPF32 MR<br>MCMPF32 MR<br>MMAXF32 MR                                                       | a, #16FHi                                                                                 | , End of Lask                                                                                                                                     |                                                     |                       |



Instruction Set

MMINF32 MRa, MRb MMINF32 MRa, #16FHi



# MMAXF32 MRa, #16FHi 32-Bit Floating-Point Maximum

| Operands    |                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                     |                     |                                         |  |  |  |
|-------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|---------------------|-----------------------------------------|--|--|--|
|             | MRa                                                            | CLA floating-po                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | int source/destination re                           | gister (MR0 to MR3) |                                         |  |  |  |
|             | #16FHi                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ate value that represent<br>low 16-bits of the mant |                     | f an IEEE 32-bit floating-<br>be all 0. |  |  |  |
| Opcode      |                                                                | III IIII IIII<br>001 0000 00aa                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                     |                     |                                         |  |  |  |
| Description |                                                                | Ra with the floating alue is larger, then                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                     | ented by the imm    | ediate operand. If the                  |  |  |  |
|             | if(MRa < #16                                                   | 6FHi:0) MRa = #16F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 'Hi:0;                                              |                     |                                         |  |  |  |
|             | floating-point<br>addressing n<br>are 0. Some<br>-1.5 (0xBFC0  | #16FHi is a 16-bit immediate value that represents the upper 16-bits of an IEEE 32-bit floating-point value. The low 16-bits of the mantissa are assumed to be all 0. This addressing mode is most useful for constants where the lowest 16-bits of the mantissa are 0. Some examples are 2.0 (0x40000000), 4.0 (0x40800000), 0.5 (0x3F000000), and -1.5 (0xBFC00000). The assembler will accept either a hex or float as the immediate value. That is, -1.5 can be represented as #-1.5 or #0xBFC0. |                                                     |                     |                                         |  |  |  |
|             | Special cases for the output from the MMAXF32 operation:       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                     |                     |                                         |  |  |  |
|             | <ul> <li>NaN output</li> </ul>                                 | NaN output will be converted to infinity                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                     |                     |                                         |  |  |  |
|             | A denorm                                                       | nalized output will t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | be converted to pos                                 | itive zero.         |                                         |  |  |  |
| Flags       | This instructi                                                 | ion modifies the fol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | lowing flags in the l                               | MSTE register       |                                         |  |  |  |
|             | Flag                                                           | TF ZF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | NF                                                  | LUF                 | LVF                                     |  |  |  |
|             | Modified                                                       | No Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Yes                                                 | No                  | No                                      |  |  |  |
|             | <pre>in the destina<br/>if(MRa == #1<br/>if(MRa &gt; #16</pre> | NF flags are config<br>ation register.<br>16FHi:0) {ZF=1; N<br>5FHi:0) {ZF=0; NF=<br>5FHi:0) {ZF=0; NF=                                                                                                                                                                                                                                                                                                                                                                                              | <pre>F=0;} 0;}</pre>                                | of the operation, i | not the result stored                   |  |  |  |
| Pipeline    | This is a sin                                                  | gle-cycle instructior                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ٦.                                                  |                     |                                         |  |  |  |
| Example     | MMOVIZ MF                                                      | R1, #4.0 ; MR1 =<br>R2, #-1.5 ; MR2 =<br>R0, #5.5 ; MR0 =                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                     | )<br>)<br>= 1       |                                         |  |  |  |
|             | MMAXF32 MF                                                     | R2, #-1.0 ; MR2 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | -1.0, ZF = 0, NF =<br>-1.5, ZF = 1, NF =            | = 1                 |                                         |  |  |  |

# MMINF32 MRa, MRb 32-Bit Floating-Point Minimum

| Operands    |                                                                                                                             |                                                         |                                                                                                                                                                                                                                                                                                                                           |                                |                      |
|-------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|----------------------|
|             | MRa                                                                                                                         | CLA floating-                                           | point source/destination regis                                                                                                                                                                                                                                                                                                            | ster (MR0 to MR3)              |                      |
|             | MRb                                                                                                                         | CLA floating-                                           | point source register (MR0 to                                                                                                                                                                                                                                                                                                             | MR3)                           |                      |
| Opcode      |                                                                                                                             | 000 0000 bbaa<br>101 0100 0000                          |                                                                                                                                                                                                                                                                                                                                           |                                |                      |
| Description | if(MRa > MR)                                                                                                                | b) MRa = MRb;                                           |                                                                                                                                                                                                                                                                                                                                           |                                |                      |
|             | Special case                                                                                                                | es for the output f                                     | rom the MMINF32 ope                                                                                                                                                                                                                                                                                                                       | ration:                        |                      |
|             | •                                                                                                                           | out will be conver                                      | •                                                                                                                                                                                                                                                                                                                                         |                                |                      |
|             | <ul> <li>A denorm</li> </ul>                                                                                                | nalized output wil                                      | I be converted to positi                                                                                                                                                                                                                                                                                                                  | ve zero.                       |                      |
| Flags       |                                                                                                                             |                                                         | ollowing flags in the M                                                                                                                                                                                                                                                                                                                   | STF register:                  |                      |
|             | Flag                                                                                                                        | TF ZF                                                   | NF                                                                                                                                                                                                                                                                                                                                        | LUF                            | LVF                  |
|             | Modified                                                                                                                    | No Yes                                                  | Yes                                                                                                                                                                                                                                                                                                                                       | No                             | No                   |
|             |                                                                                                                             | NF flags are contation register.                        | figured on the result of                                                                                                                                                                                                                                                                                                                  | the operation, n               | ot the result stored |
|             | if(MRa > MR                                                                                                                 | Rb) {ZF=1; NF=0<br>b) {ZF=0; NF=0;}<br>b) {ZF=0; NF=1;} | ;}                                                                                                                                                                                                                                                                                                                                        |                                |                      |
| Pipeline    | This is a sin                                                                                                               | gle-cycle instructi                                     | on.                                                                                                                                                                                                                                                                                                                                       |                                |                      |
| Example 1   | MMOVIZ MR1,<br>MMOVIZ MR2,<br>MMINF32 MR0<br>MMINF32 MR1<br>MMINF32 MR2                                                     | , MR2 ; MR1 = -<br>, MR1 ; MR2 = -                      | .0 (0x40800000)                                                                                                                                                                                                                                                                                                                           |                                |                      |
| Example 2   | ; Find the m                                                                                                                | rray of 32-bit f<br>minimum value in<br>it in Result    | loating-point values<br>an array X                                                                                                                                                                                                                                                                                                        |                                |                      |
|             | MUI16TOF32 I<br>MNOP<br>MNOP<br>LOOP<br>MMOV32 I<br>MMOV32 I<br>MMINF32 I<br>MADDF32 I<br>MCMPF32 I<br>MNOP<br>MNOP<br>MNOP | MR1, *MAR1[2]++<br>MR2, *MAR1[2]++<br>MR1, MR2          | <pre>; Start address<br/>; Length of the arra;<br/>; delay for MAR1 loa;<br/>; delay for MAR1 loa;<br/>; MR1 = X0<br/>; MR2 = next element<br/>; MR1 = MAX(MR1, MR2<br/>; Decrement the coun<br/>; Set/clear flags for<br/>; Branch if not equa<br/>; Always executed<br/>; Always executed<br/>; Always executed<br/>; End of task</pre> | d<br>d<br>)<br>ter<br>r MBCNDD |                      |
| See also    | MMAXF32                                                                                                                     | /IRa, MRb                                               |                                                                                                                                                                                                                                                                                                                                           |                                |                      |



MMAXF32 MRa, #16FHi MMINF32 MRa, #16FHi

# MMINF32 MRa, #16FHi 32-Bit Floating-Point Minimum

| Operands    |                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                              |                                        |                                      |  |
|-------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------|--|
|             | MRa                                                                          | floating                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | -point source/de                                                   | stination register (I                                                                                        | MR0 to MR3)                            |                                      |  |
|             | #16FHi                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                              | he upper 16-bits of a are assumed to b | an IEEE 32-bit floating-<br>e all 0. |  |
| Opcode      | LSW: IIII II<br>MSW: 0111 10                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                              |                                        |                                      |  |
| Description | Compare MF<br>immidate val                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                              | ted by the imme                        | ediate operand. If the               |  |
|             | if(MRa > #16                                                                 | 5FHi:0) MRa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | = #16FHi:0;                                                        |                                                                                                              |                                        |                                      |  |
|             | floating-point<br>addressing r<br>are 0. Some<br>-1.5 (0xBFC                 | #16FHi is a 16-bit immediate value that represents the upper 16-bits of an IEEE 32-bit floating-point value. The low 16-bits of the mantissa are assumed to be all 0. This addressing mode is most useful for constants where the lowest 16-bits of the mantissa are 0. Some examples are 2.0 (0x40000000), 4.0 (0x40800000), 0.5 (0x3F000000), and -1.5 (0xBFC00000). The assembler will accept either a hex or float as the immediate value. That is, -1.5 can be represented as #-1.5 or #0xBFC0. |                                                                    |                                                                                                              |                                        |                                      |  |
|             | Special cases for the output from the MMINF32 operation:                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                              |                                        |                                      |  |
|             | <ul> <li>NaN output will be converted to infinity</li> </ul>                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                              |                                        |                                      |  |
|             | A denormalized output will be converted to positive zero.                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                              |                                        |                                      |  |
|             | This instructi                                                               | ion modifion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | the following                                                      | flage in the M                                                                                               | STE register:                          |                                      |  |
| Flags       | Flag                                                                         | TF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ZF                                                                 | flags in the MS                                                                                              |                                        | LVF                                  |  |
|             | Modified                                                                     | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Yes                                                                | Yes                                                                                                          | No                                     | No                                   |  |
|             | The ZF and<br>in the destina<br>if(MRa == #1<br>if(MRa > #16<br>if(MRa < #16 | ation registe<br>L6FHi:0) {<br>5FHi:0) {ZF=                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <pre>r. [ZF=1; NF=0;] =0; NF=0; ]</pre>                            |                                                                                                              | the operation, n                       | not the result stored                |  |
| Pipeline    | This is a sing                                                               | gle-cycle ins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | truction.                                                          |                                                                                                              |                                        |                                      |  |
| Example     | MMOVIZ MR1<br>MMOVIZ MR2<br>MMINF32 MR0<br>MMINF32 MR1<br>MMINF32 MR2        | L, #4.0 ;<br>2, #-1.5 ;<br>0, #5.5 ;<br>L, #2.5 ;<br>2, #-1.0 ;                                                                                                                                                                                                                                                                                                                                                                                                                                      | MR1 = 4.0<br>MR2 = -1.5<br>MR0 = 5.0,<br>MR1 = 2.5,<br>MR2 = -1.5, | (0x40A00000)<br>(0x40800000)<br>(0xBFC00000)<br>ZF = 0, NF =<br>ZF = 0, NF =<br>ZF = 0, NF =<br>ZF = 1, NF = | 0<br>1                                 |                                      |  |
| See also    | MMAXF32 M<br>MMAXF32 M                                                       | IRa, #16FHi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                    |                                                                                                              |                                        |                                      |  |

# MMOV16 MARx, MRa, #16I Load the Auxiliary Register with MRa + 16-bit Immediate Value

| _ |   |    |   |    | -  |
|---|---|----|---|----|----|
| n | D | ٦r | a | nr | łc |

| Operands    |                                                                                                                                                                                                      |                                                                                                                                                                                                                                 |                                                                                              |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|
|             | MARx                                                                                                                                                                                                 | Auxiliary register M                                                                                                                                                                                                            | AR0 or MAR1                                                                                  |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
|             | MRa                                                                                                                                                                                                  | CLA Floating-point                                                                                                                                                                                                              | register (MR0 to I                                                                           | MR3)                                                                                                                                                         |                                                                                                                                                |                                                                                                                                |  |  |
|             | #16                                                                                                                                                                                                  | 16-bit immediate va                                                                                                                                                                                                             | llue                                                                                         |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
| Opcode      | LSW: IIII IIII I<br>MSW: 0111 1111 1                                                                                                                                                                 | · · ·                                                                                                                                                                                                                           | e of MMOV16 MA                                                                               | ARO, MRa, #161                                                                                                                                               | )                                                                                                                                              |                                                                                                                                |  |  |
|             | LSW: IIII IIII I<br>MSW: 0111 1111 J                                                                                                                                                                 | —                                                                                                                                                                                                                               | e of MMOV16 MA                                                                               | AR1, MRa, #161                                                                                                                                               | ])                                                                                                                                             |                                                                                                                                |  |  |
| Description | Load the auxiliar<br>Refer to the pipe<br>MARx = MRa(15:0)                                                                                                                                           | line section for in                                                                                                                                                                                                             |                                                                                              |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
| Flags       | This instruction d                                                                                                                                                                                   | loes not modify fl                                                                                                                                                                                                              | ags in the MS                                                                                | TF register:                                                                                                                                                 |                                                                                                                                                |                                                                                                                                |  |  |
|             | Flag TF                                                                                                                                                                                              | ZF                                                                                                                                                                                                                              | NF                                                                                           | LUF                                                                                                                                                          | L                                                                                                                                              | .VF                                                                                                                            |  |  |
|             | Modified No                                                                                                                                                                                          | No                                                                                                                                                                                                                              | No                                                                                           | No                                                                                                                                                           | ١                                                                                                                                              | lo                                                                                                                             |  |  |
| Pipeline    | <ul> <li>occurs. Thus</li> <li>I3 <ul> <li>Loading of an increment addregister or the mode post ind</li> <li>I4</li> <li>Starting with the MMOVI16.</li> </ul> </li> <li>i Assume MAR0 is</li> </ul> | dine. Any post ind<br>D2 phase of the p<br>sters:<br>uctions following<br>these two instruct<br>a auxiliary register<br>dressing occur in<br>ere will be a confl<br>crement will win a<br>the 4th instruction<br>50, MR0 is 10, | MMOV16 will use to the D2 phase of the case of the auxiliar of the auxiliar of the ARO or MA | R0 or MAR1 u<br>fore the follow<br>use MAR0/MA<br>the old value o<br>EXE phase w<br>. Thus I3 cann<br>of a conflict, f<br>ry register will<br>R1 will be the | ising indirect<br>ing applies v<br>R1 before th<br>f MAR0 or M<br>hile updates<br>ot use the ar<br>the update d<br>not be updat<br>new value k | addressing<br>when loading<br>are update<br>IAR1.<br>due to post-<br>uxiliary<br>ue to address-<br>ted with #_X.<br>baded with |  |  |
|             | MMOV16 MAR0, MR0, #_X       ; Load MAR0 with address of X (20) + MR0 (10)<br><instruction 1="">       ; I1 Will use the old value of MAR0 (50)</instruction>                                         |                                                                                                                                                                                                                                 |                                                                                              |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
|             | <instruction 2<br=""><instruction 3<="" th=""><th></th><th>ill use the of<br/>annot use MAR(</th><th>ld value of MA<br/>0</th><th>ARO (50)</th><th></th></instruction></instruction>                 |                                                                                                                                                                                                                                 | ill use the of<br>annot use MAR(                                                             | ld value of MA<br>0                                                                                                                                          | ARO (50)                                                                                                                                       |                                                                                                                                |  |  |
|             | <instruction 4<br=""><instruction 5<="" th=""><th></th><th>ill use the ne</th><th>ew value of MA</th><th>ARO (30)</th><th></th></instruction></instruction>                                          |                                                                                                                                                                                                                                 | ill use the ne                                                                               | ew value of MA                                                                                                                                               | ARO (30)                                                                                                                                       |                                                                                                                                |  |  |
|             | Table 8-28. Pipeline Activity For MMOV16 MARx, MRa , #16I                                                                                                                                            |                                                                                                                                                                                                                                 |                                                                                              |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
|             | Instruction                                                                                                                                                                                          | F1 F2                                                                                                                                                                                                                           | D1                                                                                           | D2 R1                                                                                                                                                        | R2                                                                                                                                             | E W                                                                                                                            |  |  |
|             | MMOV16 MAR0, MR0,                                                                                                                                                                                    | -                                                                                                                                                                                                                               |                                                                                              |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
|             | 11                                                                                                                                                                                                   |                                                                                                                                                                                                                                 | DV16                                                                                         |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
|             | 12                                                                                                                                                                                                   | l2 l1                                                                                                                                                                                                                           | MMOV16                                                                                       |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                |  |  |
|             | 13                                                                                                                                                                                                   | I3 I2                                                                                                                                                                                                                           | 11                                                                                           | MMOV16                                                                                                                                                       |                                                                                                                                                |                                                                                                                                |  |  |
|             | 14<br>15                                                                                                                                                                                             | 14 13<br>15 14                                                                                                                                                                                                                  | 12<br>13                                                                                     | 11 MMC<br>12 11                                                                                                                                              | MMOV16                                                                                                                                         |                                                                                                                                |  |  |
|             | 16                                                                                                                                                                                                   | IG I5                                                                                                                                                                                                                           | 13                                                                                           | I3 I2                                                                                                                                                        | 11                                                                                                                                             | MMOV1<br>6                                                                                                                     |  |  |

| Instruction Set | WW                                                                                       |  |  |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Example 1       | ; Calculate an offset into a sin/cos table<br>;                                          |  |  |  |  |  |  |
|                 | _ClalTask1:                                                                              |  |  |  |  |  |  |
|                 | MMOV32 MR0,@_rad ; MR0 = rad                                                             |  |  |  |  |  |  |
|                 | MMOV32 MR1,@_TABLE_SIZEDivTwoPi ; MR1 = TABLE_SIZE/(2*Pi)                                |  |  |  |  |  |  |
|                 | MMPYF32 MR1, MR0, MR1 ; MR1 = rad* TABLE_SIZE/(2*Pi)                                     |  |  |  |  |  |  |
|                 |                                                                                          |  |  |  |  |  |  |
|                 |                                                                                          |  |  |  |  |  |  |
|                 | MF32TOI32 MR3,MR1 ; MR3 = K=int(rad*TABLE_SIZE/(2*Pi))                                   |  |  |  |  |  |  |
|                 | MAND32 MR3, MR3, MR2 ; MR3 = K & TABLE_MASK                                              |  |  |  |  |  |  |
|                 | MLSL32 MR3,#1 ; MR3 = K * 2                                                              |  |  |  |  |  |  |
|                 | <pre>MMOV16 MAR0,MR3,#_Cos0 ; MAR0 K*2+addr of table.Cos0</pre>                          |  |  |  |  |  |  |
|                 | MFRACF32 MR1,MR1 ; I1                                                                    |  |  |  |  |  |  |
|                 | MMOV32 MR0,@_TwoPiDivTABLE_SIZE ; 12                                                     |  |  |  |  |  |  |
|                 | MMPYF32 MR1,MR1,MR0 ; I3                                                                 |  |  |  |  |  |  |
|                 | MMOV32 MR0,@_Coef3                                                                       |  |  |  |  |  |  |
|                 | MMOV32 MR2,*MAR0[#-64]++ ; MR2 = *MAR0, MAR0 += (-64)                                    |  |  |  |  |  |  |
|                 |                                                                                          |  |  |  |  |  |  |
|                 |                                                                                          |  |  |  |  |  |  |
|                 | MSTOP ; end of task                                                                      |  |  |  |  |  |  |
| Example 2       | ; This task logs the last NUM_DATA_POINTS<br>; ADCRESULT1 values in the array VoltageCLA |  |  |  |  |  |  |
|                 | ;                                                                                        |  |  |  |  |  |  |
|                 | ; When the last element in the array has been                                            |  |  |  |  |  |  |
|                 | ; filled, the task will go back to the                                                   |  |  |  |  |  |  |
|                 | ; the first element.                                                                     |  |  |  |  |  |  |
|                 | i                                                                                        |  |  |  |  |  |  |
|                 | ; Before starting the ADC conversions, force                                             |  |  |  |  |  |  |
|                 | ; Task 8 to initialize the ConversionCount to zero                                       |  |  |  |  |  |  |
|                 | ;                                                                                        |  |  |  |  |  |  |
|                 | _ClalTask2:                                                                              |  |  |  |  |  |  |
|                 |                                                                                          |  |  |  |  |  |  |
|                 | MMOV16 MAR1, MR0, #_VoltageCLA ;12 Next array location                                   |  |  |  |  |  |  |
|                 |                                                                                          |  |  |  |  |  |  |
|                 | MUI16TOF32 MR0, MR0 ;I3 Convert count to float32                                         |  |  |  |  |  |  |
|                 | MADDF32 MR0, MR0, #1.0 ;14 Add 1 to conversion count                                     |  |  |  |  |  |  |
|                 | MCMPF32 MR0, #NUM_DATA_POINTS.0 ;15 Compare count to max                                 |  |  |  |  |  |  |
|                 | MF32TOUI16 MR0, MR0 ;16 Convert count to Uint16                                          |  |  |  |  |  |  |
|                 | MNOP ;I7 Wait till I8 to read result                                                     |  |  |  |  |  |  |
|                 | MMOVZ16 MR2, @_AdcResult.ADCRESULT1 ;18 Read ADCRESULT1                                  |  |  |  |  |  |  |
|                 | MMOV16 *MAR1, MR2 ; Store ADCRESULT1                                                     |  |  |  |  |  |  |
|                 | MBCNDD _RestartCount, GEQ ; If count >= NUM_DATA_POINTS                                  |  |  |  |  |  |  |
|                 | MMOVIZ MR1, #0.0 ; Always executed: MR1=0                                                |  |  |  |  |  |  |
|                 | MNOP                                                                                     |  |  |  |  |  |  |
|                 | MNOP                                                                                     |  |  |  |  |  |  |
|                 |                                                                                          |  |  |  |  |  |  |
|                 | MMOV16 @_ConversionCount, MR0 ; If branch not taken                                      |  |  |  |  |  |  |
|                 | MSTOP ; store current count                                                              |  |  |  |  |  |  |
|                 | _RestartCount                                                                            |  |  |  |  |  |  |
|                 | MMOV16 @_ConversionCount, MR1 ; If branch taken, restart count                           |  |  |  |  |  |  |
|                 | MSTOP ; end of task                                                                      |  |  |  |  |  |  |
|                 | ; This task initializes the ConversionCount                                              |  |  |  |  |  |  |
|                 | ; to zero                                                                                |  |  |  |  |  |  |
|                 | ;                                                                                        |  |  |  |  |  |  |
|                 | _ClalTask8:                                                                              |  |  |  |  |  |  |
|                 | MMOVIZ MRO, #0.0                                                                         |  |  |  |  |  |  |
|                 | MMOV16 @_ConversionCount, MR0                                                            |  |  |  |  |  |  |
|                 | MSTOP                                                                                    |  |  |  |  |  |  |
|                 | _ClaT8End:                                                                               |  |  |  |  |  |  |
|                 | _014105Md.                                                                               |  |  |  |  |  |  |
| See also        |                                                                                          |  |  |  |  |  |  |
|                 |                                                                                          |  |  |  |  |  |  |



# MMOV16 MARx, mem16 Load MAR1 with 16-bit Value

## Operands

| Operands    |                                                                                                                                                                                                                                                    |                                                                                                                    |                                                                                                |                                                                                           |                                                                                            |                                                                                    |                                                                |                                                                              |                          |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------|--------------------------|
|             | MARx                                                                                                                                                                                                                                               | CLA auxiliary                                                                                                      | register MA                                                                                    | R0 or MAF                                                                                 | ۲1                                                                                         |                                                                                    |                                                                |                                                                              |                          |
|             | mem16                                                                                                                                                                                                                                              | 16-bit destina                                                                                                     | tion memor                                                                                     | y accessed                                                                                | using indire                                                                               | ect or direc                                                                       | t addressii                                                    | ng modes                                                                     |                          |
| Opcode      | LSW: mmmm mmmm mm<br>MSW: 0111 0110 00                                                                                                                                                                                                             |                                                                                                                    | pcode for                                                                                      | MMOV16                                                                                    | MARO, men                                                                                  | 16)                                                                                |                                                                |                                                                              |                          |
|             | LSW: mmmm mmmm mm<br>MSW: 0111 0110 01                                                                                                                                                                                                             |                                                                                                                    | pcode for                                                                                      | r MMOV16                                                                                  | MAR1, men                                                                                  | 16)                                                                                |                                                                |                                                                              |                          |
| Description | Load MAR0 or MA<br>section for importa<br>MAR1 = [mem16];                                                                                                                                                                                          |                                                                                                                    |                                                                                                |                                                                                           |                                                                                            |                                                                                    | Refer to                                                       | the pip                                                                      | eline                    |
| Flags       | No flags MSTF flag                                                                                                                                                                                                                                 | ns are affe                                                                                                        | rted                                                                                           |                                                                                           |                                                                                            |                                                                                    |                                                                |                                                                              |                          |
| i lago      | Flag TF                                                                                                                                                                                                                                            |                                                                                                                    | Jicu.                                                                                          | NF                                                                                        |                                                                                            | LUF                                                                                |                                                                | LVF                                                                          |                          |
|             | Modified No                                                                                                                                                                                                                                        | No                                                                                                                 |                                                                                                | No                                                                                        |                                                                                            | No                                                                                 |                                                                | No                                                                           |                          |
| Pipeline    | <ul> <li>This is a single-cyc phase of the pipeli will occur in the D2 the auxiliary regist.</li> <li>I1 and I2 The two instruct occurs. Thus the las Loading of an a increment addr register or there mode post increment.</li> <li>I4</li> </ul> | ne. Any po<br>2 phase of t<br>ers:<br>tions follow<br>ese two ins<br>auxiliary reg<br>essing occi<br>e will be a d | st increm<br>the pipeli<br>ving MMC<br>structions<br>gister occ<br>ur in the l<br>conflict. Ir | ent of MA<br>ne. There<br>DV16 will<br>s will use<br>urs in the<br>D2 phase<br>n the case | AR0 or Ma<br>ofore the f<br>use MAR<br>the old va<br>e EXE pha<br>e SThus I3<br>e of a con | AR1 usin<br>ollowing<br>0/MAR1<br>Ilue of M<br>Ise while<br>cannot u<br>flict, the | g indired<br>applies<br>before t<br>AR0 or<br>update<br>update | ct addre<br>when lo<br>he upda<br>MAR1.<br>s due to<br>auxiliary<br>due to a | ate<br>post-<br>address- |
|             | Starting with th<br>MMOV16.<br>; Assume MAR0 is<br>MMOV16 MAR0, @_X<br><instruction 1=""><br/><instruction 2=""><br/><instruction 3=""></instruction></instruction></instruction>                                                                  | 50 and @_X<br>;<br>; I1 Wi<br>; I2 Wi                                                                              | is 20<br>Load MAF<br>ll use th                                                                 | RO with t<br>ne old va<br>ne old va                                                       | he conter<br>lue of MZ<br>lue of MZ                                                        | ts of X<br>R0 (50)                                                                 |                                                                | loaded                                                                       | with                     |
|             | <instruction 3=""></instruction>                                                                                                                                                                                                                   |                                                                                                                    |                                                                                                |                                                                                           | lue of MA                                                                                  | R0 (20)                                                                            |                                                                |                                                                              |                          |
|             | <instruction 5=""></instruction>                                                                                                                                                                                                                   | ; I5                                                                                                               |                                                                                                |                                                                                           |                                                                                            | . ,                                                                                |                                                                |                                                                              |                          |
|             | Table 8                                                                                                                                                                                                                                            | -29. Pipeli                                                                                                        | ne Activi                                                                                      | ity For M                                                                                 | MOV16 N                                                                                    | IAR0/M                                                                             | AR1, me                                                        | em16                                                                         |                          |
|             | Instruction                                                                                                                                                                                                                                        | <b>F</b> 1                                                                                                         | F2                                                                                             | D1                                                                                        | D2                                                                                         | R1                                                                                 | R2                                                             | Е                                                                            | w                        |
|             | MMOV16 MAR0, @_X                                                                                                                                                                                                                                   | MMOV16                                                                                                             |                                                                                                |                                                                                           |                                                                                            |                                                                                    |                                                                | -                                                                            |                          |
|             | l1                                                                                                                                                                                                                                                 | 11                                                                                                                 | MMOV16                                                                                         |                                                                                           |                                                                                            |                                                                                    |                                                                |                                                                              |                          |
|             | 12                                                                                                                                                                                                                                                 | 12                                                                                                                 | 11                                                                                             | MMOV16                                                                                    |                                                                                            |                                                                                    |                                                                |                                                                              |                          |
|             | 13                                                                                                                                                                                                                                                 | 13                                                                                                                 | 12                                                                                             | 11                                                                                        | MMOV16                                                                                     |                                                                                    |                                                                |                                                                              |                          |
|             |                                                                                                                                                                                                                                                    |                                                                                                                    |                                                                                                |                                                                                           |                                                                                            |                                                                                    |                                                                |                                                                              |                          |

MMOV1 

MMOV16

MMOV16



| Instruction Set |                                                                                          |                               | www.t                            |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------|-------------------------------|----------------------------------|--|--|--|--|
| Example         | ; This task logs the last NUM_DATA_POINTS<br>; ADCRESULT1 values in the array VoltageCLA |                               |                                  |  |  |  |  |
|                 | ;<br>: When the lag                                                                      | t element in the array has be | en                               |  |  |  |  |
|                 |                                                                                          | task will go back to the      |                                  |  |  |  |  |
|                 | ; the first element.                                                                     |                               |                                  |  |  |  |  |
|                 | ;                                                                                        |                               |                                  |  |  |  |  |
|                 | ; Before start                                                                           | ing the ADC conversions, forc | e                                |  |  |  |  |
|                 |                                                                                          | itialize the ConversionCount  |                                  |  |  |  |  |
|                 | ;                                                                                        |                               |                                  |  |  |  |  |
|                 | _ClalTask2:                                                                              |                               |                                  |  |  |  |  |
|                 | MMOVZ16                                                                                  | MR0, @_ConversionCount        | ;I1 Current Conversion           |  |  |  |  |
|                 | MMOV16                                                                                   | MAR1, MR0, #_VoltageCLA       | ;I2 Next array location          |  |  |  |  |
|                 | MUI16TOF32                                                                               | MRO, MRO                      | ;I3 Convert count to float32     |  |  |  |  |
|                 | MADDF32                                                                                  | MR0, MR0, #1.0                | ;I4 Add 1 to conversion count    |  |  |  |  |
|                 | MCMPF32                                                                                  | MR0, #NUM_DATA_POINTS.0       | ;15 Compare count to max         |  |  |  |  |
|                 | MF32TOUI16                                                                               | MR0, MR0                      | ;I6 Convert count to Uint16      |  |  |  |  |
|                 | MNOP                                                                                     |                               | ;I7 Wait till I8 to read result  |  |  |  |  |
|                 | MMOVZ16                                                                                  | MR2, @_AdcResult.ADCRESULT1   | ;18 Read ADCRESULT1              |  |  |  |  |
|                 | MMOV16                                                                                   | *MAR1, MR2                    | ; Store ADCRESULT1               |  |  |  |  |
|                 | MBCNDD                                                                                   | _RestartCount, GEQ            | ; If count >= NUM_DATA_POINTS    |  |  |  |  |
|                 | MMOVIZ                                                                                   | MR1, #0.0                     | ; Always executed: MR1=0         |  |  |  |  |
|                 | MNOP                                                                                     |                               |                                  |  |  |  |  |
|                 | MNOP                                                                                     |                               |                                  |  |  |  |  |
|                 | MMOV16                                                                                   | @_ConversionCount, MR0        | ; If branch not taken MSTOP      |  |  |  |  |
|                 |                                                                                          |                               | ; store current count            |  |  |  |  |
|                 | _RestartCount                                                                            |                               |                                  |  |  |  |  |
|                 | MMOV16                                                                                   | @_ConversionCount, MR1        | ; If branch taken, restart count |  |  |  |  |
|                 | MSTOP                                                                                    |                               | ; end of task                    |  |  |  |  |
|                 | ; This task initializes the ConversionCount                                              |                               |                                  |  |  |  |  |
|                 | ; to zero                                                                                |                               |                                  |  |  |  |  |
|                 | ;                                                                                        |                               |                                  |  |  |  |  |
|                 | _ClalTask8:                                                                              |                               |                                  |  |  |  |  |
|                 | MMOVIZ                                                                                   | MR0, #0.0                     |                                  |  |  |  |  |
|                 | MMOV16                                                                                   | @_ConversionCount, MR0        |                                  |  |  |  |  |
|                 | MSTOP                                                                                    |                               |                                  |  |  |  |  |
|                 | _ClaT8End:                                                                               |                               |                                  |  |  |  |  |

See also



# MMOV16 mem16, MARx Move 16-Bit Auxiliary Register Contents to Memory

| -           | mem16                  | mem16 16-bit destination memory accessed using indirect or direct addressing modes |                      |                    |                 |               |  |
|-------------|------------------------|------------------------------------------------------------------------------------|----------------------|--------------------|-----------------|---------------|--|
|             | MARx                   | CL                                                                                 | A auxiliary register | MAR0 or MAR1       |                 |               |  |
| Opcode      | LSW: mmmm<br>MSW: 0111 |                                                                                    |                      | for MMOV16 meml    | 6, MAR0)        |               |  |
|             | LSW: mmmm<br>MSW: 0111 |                                                                                    | -                    | for MMOV16 mem]    | 6, MAR1)        |               |  |
| Description | Store the omem16.      | contents of                                                                        | MAR0 or MAF          | R1 in the 16-bit r | nemory location | pointed to by |  |
|             | [mem16] =              | MAR0;                                                                              |                      |                    |                 |               |  |
| Flags       | No flags M             | ISTF flags                                                                         | are affected.        |                    |                 |               |  |
|             | Flag                   | TF                                                                                 | ZF                   | NF                 | LUF             | LVF           |  |
|             | Modified               | No                                                                                 | No                   | No                 | No              | No            |  |
| Pipeline    | This is a s            | ingle-cycle                                                                        | instruction.         |                    |                 |               |  |
| Example     |                        |                                                                                    |                      |                    |                 |               |  |
| See also    |                        |                                                                                    |                      |                    |                 |               |  |

# MMOV16 mem16, MRa Move 16-Bit Floating-Point Register Contents to Memory

| Operands    |                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|--|--|
|             | mem16                                                                                                                                                                                                                                                                                                                                                        | 16-bit destination memory access                                                                                                                                                                                                                                                                                                                                                    | sed using indirect or direct add                                                                                                                                                                                                                                                                                                                                                                                          | dressing modes                                                                 |  |  |  |  |
|             | MRa                                                                                                                                                                                                                                                                                                                                                          | CLA floating-point source register                                                                                                                                                                                                                                                                                                                                                  | r (MR0 to MR3)                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                |  |  |  |  |
| Opcode      | LSW: mmmm mmmm<br>MSW: 0111 0101                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                |  |  |  |  |
| Description |                                                                                                                                                                                                                                                                                                                                                              | lue from the lower 16-bits of th<br>d to by mem16.<br>15:0);                                                                                                                                                                                                                                                                                                                        | ne floating-point register                                                                                                                                                                                                                                                                                                                                                                                                | (MRa(15:0)) to the                                                             |  |  |  |  |
| Flags       | No flags MSTF                                                                                                                                                                                                                                                                                                                                                | flags are affected.                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                |  |  |  |  |
|             | Flag TF                                                                                                                                                                                                                                                                                                                                                      | ZF NF                                                                                                                                                                                                                                                                                                                                                                               | LUF                                                                                                                                                                                                                                                                                                                                                                                                                       | LVF                                                                            |  |  |  |  |
|             | Modified No                                                                                                                                                                                                                                                                                                                                                  | o No No                                                                                                                                                                                                                                                                                                                                                                             | No                                                                                                                                                                                                                                                                                                                                                                                                                        | No                                                                             |  |  |  |  |
| Pipeline    | This is a single                                                                                                                                                                                                                                                                                                                                             | -cycle instruction.                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                |  |  |  |  |
| Example     | <pre>; ADCRESULT1 v ; ; When the las ; filled, the ; the first el ; ; Before start ; Task 8 to in ;ClalTask2:     MMOVZ16     MMOV16     MUI16TOF32     MADDF32     MADDF32     MADDF32     MMOV16     MMOV16     MMOV16     MMOV16     _RestartCount     MMOV16     _RestartCount     MMOV16     ; This task in ; to zero ;ClalTask8:     MMOVIZ MR0,</pre> | <pre>ing the ADC conversions, for<br/>itialize the ConversionCount<br/>MR0, @_ConversionCount<br/>MAR1, MR0, #_VoltageCLA<br/>MR0, MR0<br/>MR0, MR0, #1.0<br/>MR0, #NUM_DATA_POINTS.0<br/>MR0, MR0<br/>MR2, @_AdcResult.ADCRESUL<br/>*MAR1, MR2<br/>_RestartCount, GEQ<br/>MR1, #0.0<br/>@_ConversionCount, MR0<br/>@_ConversionCount, MR1<br/>hitializes the ConversionCourt</pre> | <pre>cce<br/>: to zero<br/>;Il Current Convers<br/>;I2 Next array loca<br/>;I3 Convert count t<br/>;I4 Add 1 to conver<br/>;I5 Compare count t<br/>;I6 Convert count t<br/>;I7 Wait till I8 to<br/>.T1 ;I8 Read ADCRESULT1<br/>; Store ADCRESULT1<br/>; Store ADCRESULT1<br/>; If count &gt;= NUM_E<br/>; Always executed:<br/>; If branch not tak<br/>; store current cou<br/>; If branch taken,<br/>; end of task</pre> | ation<br>to float32<br>rsion count<br>to max<br>to Uint16<br>o read result<br> |  |  |  |  |
| See also    | MMOVIZ MRa,<br>MMOVXI MRa,                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                |  |  |  |  |



# MMOV32 mem32, MRa Move 32-Bit Floating-Point Register Contents to Memory

#### Operands

| Operands    |                              |                            |                   |                                  |                   |
|-------------|------------------------------|----------------------------|-------------------|----------------------------------|-------------------|
|             | MRa                          | floating-point register (M | IR0 to MR3)       |                                  |                   |
|             | mem32                        | 32-bit destination memo    | ory accessed usir | ng indirect or direct a          | ddressing modes   |
| Opcode      | LSW: mmmm mm<br>MSW: 0111 01 |                            |                   |                                  |                   |
| Description | Move from M<br>[mem32] = MR  | Ra to 32-bit memory loc    | ation indicate    | d by mem32.                      |                   |
| Flags       | This instruction             | on modifies the following  | flags in the N    | ISTF register:                   |                   |
|             | Flag                         | TF ZF                      | NF                | LUF                              | LVF               |
|             | Modified                     | No No                      | No                | No                               | No                |
|             | No flags affe                | cted.                      |                   |                                  |                   |
| Pipeline    | This is a sing               | le-cycle instruction.      |                   |                                  |                   |
| Example     | ; Perform 5                  | multiply and accumulate    | operations:       |                                  |                   |
|             | ;                            |                            |                   |                                  |                   |
|             | ; X and Y ar                 | e 32-bit floating point    | arrays;           |                                  |                   |
|             | -                            | ly: A = X0 * Y0            |                   |                                  |                   |
|             |                              | ly: B = X1 * Y1            |                   |                                  |                   |
|             | -                            | ly: C = X2 * Y2            |                   |                                  |                   |
|             |                              | ly: D = X3 * Y3            |                   |                                  |                   |
|             | -                            | ly: E = X3 * Y3;           |                   |                                  |                   |
|             |                              | + B + C + D + E            |                   |                                  |                   |
|             | ;<br>(]1]_1;                 |                            |                   |                                  |                   |
|             | _ClalTask1:                  | MADO # Y                   | · MADO            | nointa to V on                   | ~~~~              |
|             | MMOVI16<br>MMOVI16           | MARO, #_X<br>MAR1, #_Y     |                   | points to X ar<br>points to Y ar |                   |
|             | MNOP                         | MARI, <u>#</u> 1           |                   | y for MAR0, MAR                  |                   |
|             | MNOP                         |                            |                   | y for MARO, MAR                  |                   |
|             | 11/01                        |                            |                   | MARO valid                       | 1 1044            |
|             | MMOV32                       | MR0, *MAR0[2]++            |                   | = X0, MAR0 += 2                  |                   |
|             |                              | ,                          |                   | MAR1 valid                       |                   |
|             | MMOV32                       | <pre>MR1, *MAR1[2]++</pre> | ; MR1             | = Y0, MAR1 += 2                  |                   |
|             | MMPYF32                      | MR2, MR0, MR1              |                   | = A = X0 * Y0                    |                   |
|             | MMOV32                       | MR0, *MAR0[2]++            | ; In p            | arallel MRO = X                  | 1, MAR0 += 2      |
|             | MMOV32                       | <pre>MR1, *MAR1[2]++</pre> | ; MR1             | = Y1, MAR1 += 2                  |                   |
|             | MMPYF32                      | MR3, MR0, MR1              | ; MR3             | = B = X1 * Y1                    |                   |
|             | MMOV32                       | MR0, *MAR0[2]++            | ; In p            | arallel MRO = X                  | 2, MAR0 += 2      |
|             | MMOV32                       | <pre>MR1, *MAR1[2]++</pre> | ; MR1             | = Y2, MAR2 += 2                  |                   |
|             | MMACF32                      | MR3, MR2, MR2, MRC         | •                 | •                                |                   |
|             | MMOV32                       | MR0, *MAR0[2]++            | -                 | arallel MRO = X                  | 3                 |
|             | MMOV32                       | <pre>MR1, *MAR1[2]++</pre> | ; MR1             | = Y3                             |                   |
|             | MMACF32                      | MR3, MR2, MR2, MR0         | , MR1 ; MR3       | = (A + B) + C,                   | MR2 = D = X3 * Y3 |
|             | MMOV32                       | MR0, *MAR0                 | ; In p            | arallel MRO = X                  | 4                 |
|             | MMOV32                       | MR1, *MAR1                 | ; MR1             | = Y4                             |                   |
|             | MMPYF32                      | MR2, MR0, MR1              | ; MR2             | = E = X4 * Y4                    |                   |
|             | MADDF32                      | MR3, MR3, MR2              | -                 | arallel MR3 = (                  |                   |
|             | MADDF32                      | MR3, MR3, MR2              | ; MR3             | = (A + B + C +                   | D) + E            |
|             | MMOV32                       | @_Result, MR3              | ; Stor            | e the result MS                  | TOP ; end of task |
|             |                              |                            |                   |                                  |                   |

See also

MMOV32 mem32, MSTF



# MMOV32 mem32, MSTF Move 32-Bit MSTF Register to Memory

| Operands    |                                                 |             |                      |                  |              |     |  |  |
|-------------|-------------------------------------------------|-------------|----------------------|------------------|--------------|-----|--|--|
|             | MSTF                                            | floa        | ating-point status r | egister          |              |     |  |  |
|             | mem32                                           | 32          | -bit destination me  | mory             |              |     |  |  |
| Opcode      | LSW: mmmm mmmm mmmm<br>MSW: 0111 0111 0100 addr |             |                      |                  |              |     |  |  |
| Description | Copy the C                                      | CLA's float | ing-point status     | s register, MSTF | , to memory. |     |  |  |
|             | [mem32] =                                       | MSTF;       |                      |                  |              |     |  |  |
| Flags       | This instrue                                    | ction does  | not modify flag      | gs in the MSTF   | register:    |     |  |  |
|             | Flag                                            | TF          | ZF                   | NF               | LUF          | LVF |  |  |
|             | Modified                                        | No          | No                   | No               | No           | No  |  |  |
| Pipeline    | This is a si                                    | ngle-cycle  | instruction.         |                  |              |     |  |  |
| Example     |                                                 |             |                      |                  |              |     |  |  |
| See also    | MMOV32 mem32, MRa                               |             |                      |                  |              |     |  |  |

# MMOV32 MRa, mem32 {, CNDF} Conditional 32-Bit Move

|             | MRa                                                                                                                           | MRa CLA floating-point destination register (MR0 to MR3) |                                                                     |                     |  |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------------------|---------------------|--|--|--|--|
|             | mem32                                                                                                                         |                                                          | 32-bit memory location accessed using direct or indirect addressing |                     |  |  |  |  |
|             | CNDF                                                                                                                          | optional co                                              | , ,                                                                 |                     |  |  |  |  |
|             |                                                                                                                               |                                                          |                                                                     |                     |  |  |  |  |
| pcode       |                                                                                                                               | mmmm mmmm mmmm<br>00cn dfaa addr                         |                                                                     |                     |  |  |  |  |
| Description | If the condition is true, then move the 32-bit value referenced by mem32 to the floating-<br>point register indicated by MRa. |                                                          |                                                                     |                     |  |  |  |  |
|             | if (CNDF == TRUE) MRa = [mem32];                                                                                              |                                                          |                                                                     |                     |  |  |  |  |
|             | CNDF is one of the following conditions:                                                                                      |                                                          |                                                                     |                     |  |  |  |  |
|             | Encode <sup>(1)</sup>                                                                                                         | CNDF                                                     | Description                                                         | MSTF Flags Tested   |  |  |  |  |
|             | 0000                                                                                                                          | NEQ                                                      | Not equal to zero                                                   | ZF == 0             |  |  |  |  |
|             | 0001                                                                                                                          | EQ                                                       | Equal to zero                                                       | ZF == 1             |  |  |  |  |
|             | 0010                                                                                                                          | GT                                                       | Greater than zero                                                   | ZF == 0 AND NF == 0 |  |  |  |  |
|             | 0011                                                                                                                          | GEQ                                                      | Greater than or equal to zero                                       | NF == 0             |  |  |  |  |
|             | 0100                                                                                                                          | LT                                                       | Less than zero                                                      | NF == 1             |  |  |  |  |
|             | 0101                                                                                                                          | LEQ                                                      | Less than or equal to zero                                          | ZF == 1 OR NF == 1  |  |  |  |  |
|             | 1010                                                                                                                          | TF                                                       | Test flag set                                                       | TF == 1             |  |  |  |  |
|             | 1011                                                                                                                          | NTF                                                      | Test flag not set                                                   | TF == 0             |  |  |  |  |
|             | 1100                                                                                                                          | LU                                                       | Latched underflow                                                   | LUF == 1            |  |  |  |  |
|             | 1101                                                                                                                          | LV                                                       | Latched overflow                                                    | LVF == 1            |  |  |  |  |
|             | 1110                                                                                                                          | UNC                                                      | Unconditional                                                       | None                |  |  |  |  |
|             | 1111                                                                                                                          | UNCF <sup>(2)</sup>                                      | Unconditional with flag modification                                | None                |  |  |  |  |

Flags

# This instruction modifies the following flags in the MSTE register:

| Flag     | TF | ZF  | NF  | LUF | LVF |
|----------|----|-----|-----|-----|-----|
| Modified | No | Yes | Yes | No  | No  |

{ NF = MRa(31);ZF = 0;if(MRa(30:23) == 0) { ZF = 1; NF = 0; } } else No flags modified;

Pipeline

## This is a single-cycle instruction.



Instruction Set

| Example  | <pre>; Given A, B, X, M1 and M2 are 32-bit floating-point ; numbers ; ; if(A &gt; B) calculate Y = X*M1 ; if(A &lt; B) calculate Y = X*M2 ;</pre> |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|          | _ClalTask5:                                                                                                                                       |
|          | MMOV32 MR0, @_A                                                                                                                                   |
|          | MMOV32 MR1, @_B                                                                                                                                   |
|          | MCMPF32 MR0, MRB                                                                                                                                  |
|          | $MMOV32$ MR2, @_M1, EQ ; if A > B, MR2 = M1                                                                                                       |
|          | ; Y = M1*X                                                                                                                                        |
|          | $MMOV32$ MR2, @_M2, NEQ ; if A < B, MR2 = M2                                                                                                      |
|          | $i \qquad Y = M2*X$                                                                                                                               |
|          | MMOV32 MR3, @_X                                                                                                                                   |
|          | MMPYF32 MR3, MR2, MR3 ; Calculate Y                                                                                                               |
|          | MMOV32 @_Y, MR3 ; Store Y                                                                                                                         |
|          | MSTOP ; end of task                                                                                                                               |
| See also | MMOV32 MRa, MRb {, CNDF}                                                                                                                          |

MMOVD32 MRa, mem32

# MMOV32 MRa, MRb {, CNDF} Conditional 32-Bit Move

#### Operands

| Operands    |                                        |                              |                                |                                                                                                          |                    |                  |  |  |  |
|-------------|----------------------------------------|------------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------|--------------------|------------------|--|--|--|
|             | MRa                                    | CLA                          | floating-poi                   | nt destination register (MR0 to M                                                                        | R3)                |                  |  |  |  |
|             | MRb                                    | CLA                          | floating-poi                   | nt source register (MR0 to MR3)                                                                          |                    |                  |  |  |  |
|             | CNDF                                   | optic                        | nal conditio                   | n.                                                                                                       |                    |                  |  |  |  |
| Opcode      |                                        | 0000 cndf k<br>1010 1100 (   |                                |                                                                                                          |                    |                  |  |  |  |
| Description | If the cond indicated b                |                              | then mov                       | ve the 32-bit value in MRb                                                                               | to the floatir     | g-point register |  |  |  |
|             | if (CNDF =                             | if (CNDF == TRUE) MRa = MRb; |                                |                                                                                                          |                    |                  |  |  |  |
|             | CNDF is o                              | ne of the fol                | lowing co                      | onditions:                                                                                               |                    |                  |  |  |  |
|             | Encode <sup>(3)</sup>                  | CNDF                         |                                | Description                                                                                              | MSTF Flags         | Tested           |  |  |  |
|             | 0000                                   | NEQ                          |                                | Not equal to zero                                                                                        | ZF == 0            |                  |  |  |  |
|             | 0001                                   | EQ                           |                                | Equal to zero                                                                                            | ZF == 1            |                  |  |  |  |
|             | 0010                                   | GT                           |                                | Greater than zero                                                                                        | ZF == 0 AND        | NF == 0          |  |  |  |
|             | 0011                                   | GEQ                          |                                | Greater than or equal to zero                                                                            | NF == 0            |                  |  |  |  |
|             | 0100                                   | LT                           |                                | Less than zero                                                                                           | NF == 1            |                  |  |  |  |
|             | 0101                                   | LEQ                          |                                | Less than or equal to zero                                                                               | ZF == 1 OR I       | NF == 1          |  |  |  |
|             | 1010                                   | TF                           |                                | Test flag set                                                                                            | TF == 1            |                  |  |  |  |
|             | 1011                                   | NTF                          |                                | Test flag not set                                                                                        | TF == 0            |                  |  |  |  |
|             | 1100                                   | LU                           |                                | Latched underflow                                                                                        | LUF == 1           |                  |  |  |  |
|             | 1101                                   | LV                           |                                | Latched overflow                                                                                         | LVF == 1           |                  |  |  |  |
|             | 1110                                   | UNC                          |                                | Unconditional                                                                                            | None               |                  |  |  |  |
|             | 1111                                   | UNCF <sup>(4)</sup>          |                                | Unconditional with flag modification                                                                     | None               |                  |  |  |  |
| Flags       | <sup>(4)</sup> This is th<br>be modifi | ied when a cor               | ation if no C<br>iditional ope | NDF field is specified. This condi<br>eration is executed. All other cond<br>lowing flags in the MSTF re | litions will not m |                  |  |  |  |
|             | Flag                                   | TF                           | ZF                             | NF                                                                                                       | LUF                | LVF              |  |  |  |
|             | Modified                               | No                           | Yes                            | Yes                                                                                                      | No                 | No               |  |  |  |

| Modified     | No        | Yes            | Yes      |
|--------------|-----------|----------------|----------|
| if(CNDF<br>{ | == UNCF)  |                |          |
| NF =         | MRa(31);  | ZF = 0;        |          |
| if(M         | Ra(30:23) | == 0) {ZF = 1; | NF = 0;} |

## Pipeline

This is a single-cycle instruction.

else No flags modified;

}



| Instruction | Set |
|-------------|-----|
|-------------|-----|

| ; | Given: X = | 8.0  |      |                     |   |                                |
|---|------------|------|------|---------------------|---|--------------------------------|
| ; | Y =        | 7.0  |      |                     |   |                                |
| ; | A =        | 2.0  |      |                     |   |                                |
| ; | В =        | 5.0  |      |                     |   |                                |
| ; | _ClaTask1  |      |      |                     |   |                                |
|   | MMOV32     | MR3, | @_X  |                     | ; | MR3 = X = 8.0                  |
|   | MMOV32     | MR0, | @_Y  |                     | ; | MR0 = Y = 7.0                  |
|   | MMAXF32    | MR3, | MR0  |                     | ; | ZF = 0, $NF = 0$ , $MR3 = 8.0$ |
|   | MMOV32     | MR1, | @_A, | $\operatorname{GT}$ | ; | true, MR1 = $A = 2.0$          |
|   | MMOV32     | MR1, | @_B, | LT                  | ; | false, does not load MR1       |
|   | MMOV32     | MR2, | MR1, | $\operatorname{GT}$ | ; | true, MR2 = MR1 = 2.0          |
|   | MMOV32     | MR2, | MR0, | LT                  | ; | false, does not load MR2       |
|   | MSTOP      |      |      |                     |   |                                |
|   |            |      |      |                     |   |                                |

See also

MMOV32 MRa, mem32 {,CNDF}



# MMOV32 MSTF, mem32 Move 32-Bit Value from Memory to the MSTF Register

| Operatius   |                           |            |                                    |                    |                   |                    |       |
|-------------|---------------------------|------------|------------------------------------|--------------------|-------------------|--------------------|-------|
|             | MSTF                      | CL         | A status register                  |                    |                   |                    |       |
|             | mem32                     | 32         | bit source memory                  | / location         |                   |                    |       |
| Opcode      | LSW: mmmm n               | ammm mmmm  | mmmm                               |                    |                   |                    |       |
|             | MSW: 0111 (               | 0111 0000  | addr                               |                    |                   |                    |       |
| Description |                           |            | o the CLA's sta<br>n calls (via MC |                    | TF. This instruct | ion is most useful |       |
|             | MSTF = [men               | -          |                                    |                    |                   |                    |       |
|             | MSIF - [men               | 1.52]/     |                                    |                    |                   |                    |       |
| Flags       | This instruc              | tion modi  | fies the followir                  | ng flags in the M  | ISTF register:    |                    |       |
|             | Flag                      | TF         | ZF                                 | NF                 | LUF               | LVF                |       |
|             | Modified                  | Yes        | Yes                                | Yes                | Yes               | Yes                |       |
|             | Loading the is not affect |            | egister will over                  | write all flags ar | nd the RPC field. | The MEALLOW 1      | field |
| Pipeline    | This is a sir             | ngle-cycle | instruction.                       |                    |                   |                    |       |
| Example     |                           |            |                                    |                    |                   |                    |       |
| See also    | MMOV32 m                  | nem32, M   | STF                                |                    |                   |                    |       |
|             |                           |            |                                    |                    |                   |                    |       |

# MMOVD32 MRa, mem32 Move 32-Bit Value from Memory with Data Copy

#### Operands

| Operands    |                                                                                                |                                 |                            |                         |                     |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------|---------------------------------|----------------------------|-------------------------|---------------------|--|--|--|--|
|             | MRa                                                                                            | CLA floating-p                  | oint register (MR0 to MR3) |                         |                     |  |  |  |  |
|             | mem32                                                                                          | 32-bit memory                   | location accessed using d  | irect or indirect addre | essing              |  |  |  |  |
| Opcode      | LSW: mmmm mmmm mmmm<br>MSW: 0111 0100 00aa addr                                                |                                 |                            |                         |                     |  |  |  |  |
| Description | Move the 32-<br>MRa.                                                                           | bit value referend              | ed by mem32 to the         | floating-point rec      | jister indicated by |  |  |  |  |
|             | MRa = [mem32<br>[mem32+2] =                                                                    |                                 |                            |                         |                     |  |  |  |  |
| Flags       | This instruction modifies the following flags in the MSTF register:                            |                                 |                            |                         |                     |  |  |  |  |
|             |                                                                                                | TF ZF                           | NF<br>Yes                  | LUF                     | LVF<br>No           |  |  |  |  |
|             | NF = MRa(31)<br>ZF = 0;                                                                        | No Yes<br>;<br>) == 0){ ZF = 1; |                            | No                      |                     |  |  |  |  |
| Pipeline    | This is a sing                                                                                 | le-cycle instructio             | on.                        |                         |                     |  |  |  |  |
| Example     | <pre>This is a single-cycle instruction. ; sum = X0*B0 + X1*B1 + X2*B2 + Y1*A1 + Y2*B2 ;</pre> |                                 |                            |                         |                     |  |  |  |  |

See also

MMOV32 MRa, mem32 {,CNDF}



# MMOVF32 MRa, #32F Load the 32-Bits of a 32-Bit Floating-Point Register

| Operands                                 |                                                                                                                                         | is an alias for MMO                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                        |                                                                                               | he second operand                                                    |  |  |  |  |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--|--|--|--|
|                                          | MMOVIZ MRa, #16FHiHex MMOVXI MRa, #16FLoHex                                                                                             |                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                        |                                                                                               |                                                                      |  |  |  |  |
|                                          | MRa                                                                                                                                     | CLA floating-point de                                                                                                                                                                                                                                                                                                             | stination register (M                                                                                                                                                                                                                                  | R0 to MR3)                                                                                    |                                                                      |  |  |  |  |
|                                          | #32F                                                                                                                                    | immediate float value                                                                                                                                                                                                                                                                                                             | represented in float                                                                                                                                                                                                                                   | ting-point representa                                                                         | tion                                                                 |  |  |  |  |
|                                          |                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                        |                                                                                               |                                                                      |  |  |  |  |
| Opcode                                   |                                                                                                                                         | IIII IIII (opcode                                                                                                                                                                                                                                                                                                                 | of MMOVIZ MRa,                                                                                                                                                                                                                                         | #16FHiHex)                                                                                    |                                                                      |  |  |  |  |
|                                          | MSW: 0111 1000<br>LSW: IIII IIII                                                                                                        | IIII IIII (opcode                                                                                                                                                                                                                                                                                                                 | of MMOVXI MRa.                                                                                                                                                                                                                                         | #16FLoHex)                                                                                    |                                                                      |  |  |  |  |
|                                          | MSW: 0111 1000                                                                                                                          |                                                                                                                                                                                                                                                                                                                                   | ,                                                                                                                                                                                                                                                      | ,                                                                                             |                                                                      |  |  |  |  |
| Description                              | representation.                                                                                                                         | ruction accepts the in<br>To specify the imme<br>se the MOVI32 MRa,                                                                                                                                                                                                                                                               | diate value as a                                                                                                                                                                                                                                       | a hex value (IEE                                                                              |                                                                      |  |  |  |  |
|                                          | Load the 32-bit                                                                                                                         | s of MRa with the im                                                                                                                                                                                                                                                                                                              | mediate float va                                                                                                                                                                                                                                       | lue represented                                                                               | by #32F.                                                             |  |  |  |  |
|                                          | #32F is a float                                                                                                                         | value represented in                                                                                                                                                                                                                                                                                                              | floating-point re                                                                                                                                                                                                                                      | presentation. Th                                                                              | ne assembler will on                                                 |  |  |  |  |
|                                          |                                                                                                                                         | alue represented in t                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                        |                                                                                               |                                                                      |  |  |  |  |
|                                          | represented as                                                                                                                          | #3.0. #0x40400000                                                                                                                                                                                                                                                                                                                 | will result in an                                                                                                                                                                                                                                      | error.                                                                                        |                                                                      |  |  |  |  |
|                                          | MRa = #32F;                                                                                                                             |                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                        |                                                                                               |                                                                      |  |  |  |  |
|                                          | 11tta =   521 /                                                                                                                         |                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                        |                                                                                               |                                                                      |  |  |  |  |
| Flags                                    |                                                                                                                                         | modifies the followir                                                                                                                                                                                                                                                                                                             | na flaas in the M                                                                                                                                                                                                                                      | STF register                                                                                  |                                                                      |  |  |  |  |
| Flags                                    | This instruction                                                                                                                        | modifies the followir                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                        |                                                                                               | LVF                                                                  |  |  |  |  |
| Flags                                    | This instruction<br>Flag TF                                                                                                             | ZF                                                                                                                                                                                                                                                                                                                                | NF                                                                                                                                                                                                                                                     | LUF                                                                                           | LVF                                                                  |  |  |  |  |
| Flags                                    | This instruction                                                                                                                        | ZF                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                        |                                                                                               | LVF<br>No                                                            |  |  |  |  |
| -                                        | This instructionFlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point for                                             | ZF                                                                                                                                                                                                                                                                                                                                | NF<br>No<br>on takes one or t<br>nat of #32F are a<br>IZ instruction. If<br>t zeros, then the                                                                                                                                                          | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits                     | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Pipeline                                 | FlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point fointo MMOVIZ a                                                 | <b>ZF</b><br>No<br>#32FH, this instruction<br>bit floating-point form<br>F32 into only MMOV<br>prmat of #32F are no<br>and MMOVXI instruct                                                                                                                                                                                        | NF<br>No<br>on takes one or t<br>nat of #32F are a<br>IZ instruction. If<br>t zeros, then the<br>ions.                                                                                                                                                 | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits                     | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Pipeline                                 | This instructionFlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point for                                             | <b>ZF</b><br>No<br>W32FH, this instruction-<br>bit floating-point form<br>F32 into only MMOV<br>format of #32F are no<br>and MMOVXI instruct<br>3.0 ; MR1 = 3.0                                                                                                                                                                   | NF<br>No<br>on takes one or t<br>nat of #32F are a<br>IZ instruction. If<br>t zeros, then the<br>ions.                                                                                                                                                 | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits<br>assembler will o | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Pipeline                                 | FlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point fointo MMOVIZ a                                                 | <b>ZF</b><br>No<br>W32FH, this instruction-<br>bit floating-point form<br>F32 into only MMOV<br>format of #32F are no<br>and MMOVXI instruct<br>3.0 ; MR1 = 3.0                                                                                                                                                                   | NF<br>No<br>on takes one or t<br>nat of #32F are a<br>IZ instruction. If<br>t zeros, then the<br>ions.<br>(0x40400000)<br>converts this i                                                                                                              | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits<br>assembler will o | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Pipeline                                 | This instructionFlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point fointo MMOVIZ aMMOVF32MR1, #                    | <b>ZF</b><br>No<br>W32FH, this instruction-<br>bit floating-point form<br>F32 into only MMOV<br>format of #32F are not<br>and MMOVXI instruct<br>(3.0 ; MR1 = 3.0<br>; Assembler<br>; MMOVIZ MR1                                                                                                                                  | NF<br>No<br>on takes one or t<br>nat of #32F are i<br>IZ instruction. If<br>t zeros, then the<br>ions.<br>(0x4040000)<br>converts this i<br>, #0x4040                                                                                                  | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits<br>assembler will o | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Pipeline                                 | This instructionFlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point forinto MMOVIZ a                                | <b>ZF</b><br>No<br>W32FH, this instruction-<br>bit floating-point form<br>F32 into only MMOV<br>format of #32F are no<br>and MMOVXI instruct<br>3.0 ; MR1 = 3.0<br>; Assembler<br>; MMOVIZ MR1<br>0.0 ; MR2 = 0.0                                                                                                                 | NF<br>No<br>on takes one or t<br>nat of #32F are i<br>IZ instruction. If<br>t zeros, then the<br>ions.<br>(0x4040000)<br>converts this i<br>, #0x4040                                                                                                  | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits<br>assembler will o | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Pipeline                                 | This instructionFlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point fointo MMOVIZ aMMOVF32MR1, #                    | <b>ZF</b><br>No<br>W32FH, this instruction-<br>bit floating-point form<br>F32 into only MMOV<br>format of #32F are no<br>and MMOVXI instruct<br>3.0 ; MR1 = 3.0<br>; Assembler<br>; MMOVIZ MR1<br>0.0 ; MR2 = 0.0                                                                                                                 | NF<br>No<br>on takes one or t<br>nat of #32F are i<br>IZ instruction. If<br>t zeros, then the<br>ions.<br>(0x4040000)<br>converts this i<br>, #0x4040<br>(0x0000000)<br>converts this i                                                                | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits<br>assembler will o | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Pipeline                                 | FlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point fcinto MMOVF32 MR1, #MMOVF32 MR2, #                             | <b>ZF</b><br>No<br>W32FH, this instruction-<br>bit floating-point form<br>F32 into only MMOV<br>format of #32F are no<br>and MMOVXI instruct<br>3.0 ; MR1 = 3.0<br>; Assembler<br>; MMOVIZ MR1<br>50.0 ; MR2 = 0.0<br>; Assembler<br>; MMOVIZ MR2<br>512.265 ; MR3 = 12.6                                                         | NF<br>No<br>on takes one or t<br>nat of #32F are in<br>IZ instruction. If<br>t zeros, then the<br>ions.<br>(0x40400000)<br>converts this i<br>, #0x4040<br>(0x0000000)<br>converts this i<br>, #0x0<br>25 (0x41443D71)<br>converts this i<br>, #0x4144 | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits<br>assembler will o | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Pipeline<br>Example                      | FlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point fcinto MMOVF32 MR1, #MMOVF32 MR2, #MMOVF32 MR3, #MMOVF32 MR3, # | <b>ZF</b><br>No<br>#32FH, this instruction-<br>bit floating-point form<br>F32 into only MMOV<br>format of #32F are no<br>and MMOVXI instruct<br>3.0 ; MR1 = 3.0<br>; Assembler<br>; MMOVIZ MR1<br>40.0 ; MR2 = 0.0<br>; Assembler<br>; MMOVIZ MR2<br>412.265 ; MR3 = 12.6<br>; Assembler<br>; MMOVIZ MR3<br>#16FHi                | NF<br>No<br>on takes one or t<br>nat of #32F are in<br>IZ instruction. If<br>t zeros, then the<br>ions.<br>(0x40400000)<br>converts this i<br>, #0x4040<br>(0x0000000)<br>converts this i<br>, #0x0<br>25 (0x41443D71)<br>converts this i<br>, #0x4144 | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits<br>assembler will o | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |
| Flags<br>Pipeline<br>Example<br>See also | FlagTFModifiedNoDepending on aof the IEEE 32-convert MMOVfloating-point fcinto MMOVF32 MR1, #MMOVF32 MR2, #MMOVF32 MR3, #               | ZF<br>No<br>#32FH, this instruction<br>bit floating-point form<br>F32 into only MMOV<br>format of #32F are no<br>and MMOVXI instruct<br>3.0 ; MR1 = 3.0<br>; Assembler<br>; MMOVIZ MR1<br>40.0 ; MR2 = 0.0<br>; Assembler<br>; MMOVIZ MR2<br>412.265 ; MR3 = 12.6<br>; Assembler<br>; MMOVIZ MR3<br>#16FHi<br>#16FHi<br>#16FLoHex | NF<br>No<br>on takes one or t<br>nat of #32F are i<br>IZ instruction. If<br>t zeros, then the<br>ions.<br>(0x40400000)<br>converts this i<br>, #0x4040<br>(0x0000000)<br>converts this i<br>, #0x0<br>25 (0x41443D71)<br>converts this i<br>, #0x4144  | LUF<br>No<br>two cycles. If all<br>zeros, then the a<br>the lower 16-bits<br>assembler will o | No<br>of the lower 16-bits<br>assembler will<br>s of the IEEE 32-bit |  |  |  |  |

# MMOVI16 MARx, #16I Load the Auxiliary Register with the 16-Bit Immediate Value

# Operands

| Operands    |                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                       |                                                              |                               |                                     |                           |         |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------|-------------------------------------|---------------------------|---------|
|             | MARx                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Auxiliary regis                                                                       | ter MAR0 or MAR                                              | 1                             |                                     |                           |         |
|             | #16l                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 16-bit immedi                                                                         | ate value                                                    |                               |                                     |                           |         |
| Opcode      | LSW: IIII III<br>MSW: 0111 111                                                                                                                                                                                                                                                                                                                                                                                                                         | II IIII IIII (op<br>11 1100 0000                                                      | ocode of MMOVI                                               | 16 MAR0, #10                  | 51)                                 |                           |         |
|             | LSW: IIII III<br>MSW: 0111 111                                                                                                                                                                                                                                                                                                                                                                                                                         | II IIII IIII (op<br>11 1110 0000                                                      | ocode of MMOVI                                               | 16 MAR1, #10                  | δΙ)                                 |                           |         |
| Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                        | iliary register, M/<br>on for important                                               |                                                              |                               |                                     | ue. Refer                 | to the  |
| Flags       | This instruction                                                                                                                                                                                                                                                                                                                                                                                                                                       | on does not mod                                                                       | ify flags in the                                             | MSTF regist                   | er:                                 |                           |         |
|             | Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                   | TF ZF                                                                                 | NF                                                           | :                             | LUF                                 | LVF                       |         |
|             | Modified                                                                                                                                                                                                                                                                                                                                                                                                                                               | No No                                                                                 | No                                                           | 1                             | No                                  | No                        |         |
| Pipeline    | EXE phase of<br>addressing w                                                                                                                                                                                                                                                                                                                                                                                                                           | le-cycle instruction<br>f the pipeline. Ar<br>ill occur in the D<br>the auxiliary reg | ly post increments of the                                    | ent of MAR0                   | or MAR1 using                       | indirect                  |         |
|             | occurs. Th                                                                                                                                                                                                                                                                                                                                                                                                                                             | nstructions follow<br>hus these two ins                                               |                                                              |                               |                                     |                           | ate     |
|             | increment<br>register or                                                                                                                                                                                                                                                                                                                                                                                                                               | f an auxiliary reg<br>addressing occu<br>there will be a c<br>t increment will v      | ur in the D2 ph<br>conflict. In the                          | ase. Thus I3<br>case of a cor | cannot use the<br>flict, the update | e auxiliary<br>e due to a | ddress- |
|             | • 14                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                       |                                                              |                               |                                     |                           |         |
|             | Starting w<br>MMOVI16                                                                                                                                                                                                                                                                                                                                                                                                                                  | ith the 4th instru                                                                    | ction MAR0 or                                                | MAR1 will b                   | e the new value                     | e loaded v                | vith    |
|             | ; Assume MAR                                                                                                                                                                                                                                                                                                                                                                                                                                           | R0 is 50 and #_1                                                                      | K is 20                                                      |                               |                                     |                           |         |
|             | MMOVI16 MAR0<br><instruction<br><instruction<br><instruction<br><instruction<br><instruction< th=""><th>1&gt;       ; I         2&gt;       ; I         3&gt;       ; I         4&gt;       ; I</th><th>Will use the<br/>Will use the<br/>Cannot use M<br/>Will use the</th><th>e old value o<br/>MARO</th><th>of MAR0 (50)<br/>of MAR0 (50)</th><th></th><th></th></instruction<></instruction<br></instruction<br></instruction<br></instruction<br> | 1>       ; I         2>       ; I         3>       ; I         4>       ; I           | Will use the<br>Will use the<br>Cannot use M<br>Will use the | e old value o<br>MARO         | of MAR0 (50)<br>of MAR0 (50)        |                           |         |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                        | able 8-30. Pipe                                                                       | ine Activity F                                               | or MMOVI16                    | 6 MAR0/MAR1.                        | #16                       |         |
|             | Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                            | F1                                                                                    | F2 D1                                                        | D2                            | R1 R2                               | E                         | w       |
|             | MMOVI16 MAR0,                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                       |                                                              |                               |                                     | -                         |         |
|             | l1                                                                                                                                                                                                                                                                                                                                                                                                                                                     | I1                                                                                    | MMOVI16                                                      |                               |                                     |                           |         |
|             | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 12                                                                                    | I1 MMO                                                       | VI16                          |                                     |                           |         |
|             | 13                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 13                                                                                    | 12 11                                                        | MMOVI16                       |                                     |                           |         |
|             | 14                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 14                                                                                    | 13 12                                                        | l1                            | MMOVI16                             |                           |         |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                       |                                                              |                               |                                     |                           |         |

15

16

11

12

12

13

MMOVI16

11

MMOVI 16

14

15

13

14

15

16



# MMOVI32 MRa, #32FHex Load the 32-Bits of a 32-Bit Floating-Point Register with the Immediate

| Operands    |                                     |                                 |                                                          |                                           |                                                              |                                 |
|-------------|-------------------------------------|---------------------------------|----------------------------------------------------------|-------------------------------------------|--------------------------------------------------------------|---------------------------------|
|             | MRa                                 | floating-p                      | oint register (MR                                        | 0 to MR3)                                 |                                                              |                                 |
|             | #32FHex                             | A 32-bit i                      | mmediate value t                                         | hat represents an IE                      | EE 32-bit floating-po                                        | oint value.                     |
|             |                                     |                                 |                                                          | and MMOVXI in the instruction             | structions. The s<br>becomes:                                | second operand                  |
|             | MMOVIZ MRa,<br>MMOVXI MRa,          |                                 |                                                          |                                           |                                                              |                                 |
| Opcode      |                                     | III IIII IIII<br>)00 0100 00aa  | -                                                        | IMOVIZ MRa, #161                          | FHiHex)                                                      |                                 |
|             |                                     | III IIII IIII<br>)00 1000 00aa  | -                                                        | MOVXI MRa, #16                            | FLoHex)                                                      |                                 |
| Description |                                     |                                 |                                                          |                                           | mmediate operar<br>the MMOVF32                               | nd. To specify the<br>MRa, #32F |
|             | Load the 32-                        | bits of MRa v                   | vith the immed                                           | liate 32-bit hex                          | value represente                                             | ed by #32Fhex.                  |
|             | value of a flo                      | pating-point n                  | umber. The as                                            | sembler will onl                          | s the IEEE 32-bi<br>y accept a hex in<br>#3.0 will result in | mmediate value.                 |
|             | MRa = #32FHe                        | ex;                             |                                                          |                                           |                                                              |                                 |
| Flags       | This instructi                      | ion modifies t                  | he followina fla                                         | ags in the MSTF                           | - register:                                                  |                                 |
|             | Flag                                |                                 | ZF                                                       | NF                                        | LUF                                                          | LVF                             |
|             | Modified                            | No                              | No                                                       | No                                        | No                                                           | No                              |
| Pipeline    | bits of #32FI<br>instruction. If    | Hex are zeros<br>f the lower 16 | , then assemb                                            | oler will convert<br>lex are not zero     | vo cycles. If all of<br>MOVI32 to the M<br>s, then assemble  | MOVIZ                           |
| Example     | MOVI32 MRI                          | L, #0x4040000                   | 0 ; MRl = 0x4<br>; Assembler<br>; MMOVIZ MF              | converts this                             | instruction as                                               |                                 |
|             | MOVI32 MR2,                         | , #0x0000000                    |                                                          | converts this                             | instruction as                                               |                                 |
|             | MOVI32 MR3,                         | , #0x40004001                   | ; MR3 = 0x4<br>; Assembler<br>; MMOVIZ MF<br>; MMOVXI MF | converts this<br>3, #0x4000               | instruction as                                               |                                 |
|             | MOVI32 MR0,                         | , #0x00004040                   | ; MRO = 0xO<br>; Assembler<br>; MMOVIZ MF<br>; MMOVXI MF | converts this converts this converts this | instruction as                                               |                                 |
| See also    | MMOVIZ MF<br>MMOVXI MF<br>MMOVF32 N | Ra, #16FLoHe                    | эх                                                       |                                           |                                                              |                                 |

# MMOVIZ MRa, #16FHi Load the Upper 16-Bits of a 32-Bit Floating-Point Register

| Operands    |                                  |                                         |                                                       |                                                  |                                                             |                                       |            |
|-------------|----------------------------------|-----------------------------------------|-------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------|---------------------------------------|------------|
|             | MRa                              | floa                                    | ating-point registe                                   | r (MR0 to MR3)                                   |                                                             |                                       |            |
|             | #16FHi                           |                                         |                                                       |                                                  | s the upper 16-bits of<br>ssa are assumed to b              | an IEEE 32-bit floating-<br>be all 0. |            |
| Opcode      | LSW: IIII I<br>MSW: 0111 I       |                                         |                                                       |                                                  |                                                             |                                       |            |
| Description | Load the up<br>bits of MRa       |                                         | its of MRa with                                       | the immediate                                    | value #16FHi an                                             | d clear the low 16-                   |            |
|             | bit floating-<br>assembler       | point valu<br>will only a               | e. The low 16-                                        | bits of the mant                                 | ents the upper 16<br>issa are assume<br>liate value. That i |                                       | <u>?</u> - |
|             | the lowest 7<br>(0x4080000       | 16-bits of<br>)0), 0.5 (0<br>ating-poin | the mantissa a<br>0x3F000000), a<br>it register to be | are 0. Some exa<br>and -1.5 (0xBFC               | amples are 2.0 (0                                           | tant requires all 32                  |            |
|             | MRa(31:16)<br>MRa(15:0)          |                                         | ;                                                     |                                                  |                                                             |                                       |            |
| Flags       | This instruc                     | tion modi                               | fies the followi                                      | ng flags in the N                                | MSTF register:                                              |                                       |            |
|             | Flag                             | TF                                      | ZF                                                    | NF                                               | LUF                                                         | LVF                                   |            |
|             | Modified                         | No                                      | No                                                    | No                                               | No                                                          | No                                    |            |
| Pipeline    | This is a sir                    | ngle-cycle                              | instruction.                                          |                                                  |                                                             |                                       |            |
| Example     | ; Load MR0<br>MMOVII<br>MMOVII   | z mr0,                                  |                                                       | BFC00000)<br>; MR0 = 0xBFC00<br>; MR0 = -1.5 (0  |                                                             |                                       |            |
|             | ; Load MR2<br>MMOVII<br>MMOVXI   | z MR2,                                  |                                                       | x40490FDB)<br>; MR0 = 0x40490<br>; MR0 = 0x40490 |                                                             |                                       |            |
| See also    | MMOVF32<br>MMOVI32 I<br>MMOVXI M | MRa, #32                                | FHex                                                  |                                                  |                                                             |                                       |            |



# MMOVZ16 MRa, mem16 Load MRx With 16-bit Value

| MRa              | CL                                         | A floating-point de                                                            | stination register (MI                                                                                                       | R0 to MR3)                                                                                                                                    |                                                                                                                                                                |
|------------------|--------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mem16            | 16                                         | -bit source memory                                                             | location                                                                                                                     |                                                                                                                                               |                                                                                                                                                                |
| LSW: mmmm        | mmmm mmmm                                  | mmmm                                                                           |                                                                                                                              |                                                                                                                                               |                                                                                                                                                                |
| MSW: 0111        | 0101 10aa                                  | addr                                                                           |                                                                                                                              |                                                                                                                                               |                                                                                                                                                                |
| Move the<br>MRa. | 16-bit valu                                | e referenced by                                                                | mem16 to the                                                                                                                 | floating-point reg                                                                                                                            | gister indicated by                                                                                                                                            |
| MRa(31:16)       | ) = 0;                                     |                                                                                |                                                                                                                              |                                                                                                                                               |                                                                                                                                                                |
| MRa(15:0)        | = [mem16]                                  | ;                                                                              |                                                                                                                              |                                                                                                                                               |                                                                                                                                                                |
|                  |                                            |                                                                                | ng flags in the M                                                                                                            | STF register:                                                                                                                                 |                                                                                                                                                                |
|                  |                                            |                                                                                | ng flags in the M<br>NF                                                                                                      | STF register:<br>LUF                                                                                                                          | LVF                                                                                                                                                            |
| This instru      | iction modi                                | ifies the followir                                                             | 0 0                                                                                                                          | •                                                                                                                                             | LVF<br>No                                                                                                                                                      |
|                  | LSW: mmmm<br>MSW: 0111<br>Move the<br>MRa. | mem16 16<br>LSW: mmmm mmmm mmmm<br>MSW: 0111 0101 10aa<br>Move the 16-bit valu | mem16 16-bit source memory<br>LSW: mmmm mmmm mmmm<br>MSW: 0111 0101 10aa addr<br>Move the 16-bit value referenced by<br>MRa. | mem1616-bit source memory locationLSW: mmmm mmmm mmmm mmmmMSW: 0111 0101 10aa addrMove the 16-bit value referenced by mem16 to the to<br>MRa. | mem1616-bit source memory locationLSW: mmmm mmmm mmmm mmmm mmmmMSW: 0111 0101 10aa addrMove the 16-bit value referenced by mem16 to the floating-point regMRa. |

# MMOVXI MRa, #16FLoHex Move Immediate to the Low 16-Bits of a Floating-Point Register

| operanas    |                           |            |                     |                                                |                   |                                                         |
|-------------|---------------------------|------------|---------------------|------------------------------------------------|-------------------|---------------------------------------------------------|
|             | MRa                       | CI         | A floating-point re | gister (MR0 to MR3)                            |                   |                                                         |
|             | #16FLoHex                 |            |                     | ex value that represe<br>The upper 16-bits wil |                   | s of an IEEE 32-bit                                     |
| Opcode      | LSW: IIII I               | IIII IIII  | IIII                |                                                |                   |                                                         |
|             | MSW: 0111 1               | 1000 1000  | 00aa                |                                                |                   |                                                         |
| Description | represents<br>MRa will no | the lower  | 16-bits of an I     | can be combine                                 | ng-point value. T | #16FLoHex<br>The upper 16-bits of<br>VIZ instruction to |
|             | MRa(15:0) =<br>MRa(31:16) | = #16FLoH  | lex;                |                                                |                   |                                                         |
| Flags       |                           |            |                     |                                                |                   |                                                         |
|             | Flag                      | TF         | ZF                  | NF                                             | LUF               | LVF                                                     |
|             | Modified                  | No         | No                  | No                                             | No                | No                                                      |
| Pipeline    | This is a sir             | ngle-cycle | e instruction.      |                                                |                   |                                                         |
| Example     | ; Load MR0                | with pi    | = 3.141593 (02      | (40490FDB)                                     |                   |                                                         |
|             | MMOVIZ                    |            | ,                   | $IR0 = 0 \times 40490000$                      | -                 |                                                         |
|             | MMOVXI                    | MRC        | ),#0x0FDB ; N       | IR0 = 0x40490FDE                               | 3                 |                                                         |
|             |                           |            |                     |                                                |                   |                                                         |
| See also    | MMOVIZ M                  | IRa, #16F  | -Hi                 |                                                |                   |                                                         |

# MMPYF32 MRa, MRb, MRc 32-Bit Floating-Point Multiply

| Operands    |                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                |                                                                                                 |                                                                                                |     |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----|
|             | MRa                                                                                                                                                                                                                                                                           | CLA floating-poi                                                                                                                                                                               | nt destination register (M                                                                      | R0 to MR3)                                                                                     |     |
|             | MRb                                                                                                                                                                                                                                                                           | CLA floating-poi                                                                                                                                                                               | nt source register (MR0 t                                                                       | o MR3)                                                                                         |     |
|             | MRc                                                                                                                                                                                                                                                                           | • •                                                                                                                                                                                            | nt source register (MR0 t                                                                       | ,                                                                                              |     |
|             |                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                |                                                                                                 |                                                                                                |     |
| Opcode      |                                                                                                                                                                                                                                                                               | 000 00cc bbaa<br>.00 0000 0000                                                                                                                                                                 |                                                                                                 |                                                                                                |     |
| Description | Multiply the of<br>MRa = MRb *                                                                                                                                                                                                                                                |                                                                                                                                                                                                | ting-point registers.                                                                           |                                                                                                |     |
| Flags       | This instructi                                                                                                                                                                                                                                                                | on modifies the foll                                                                                                                                                                           | owing flags in the N                                                                            | ISTF register:                                                                                 |     |
|             | Flag                                                                                                                                                                                                                                                                          | TF ZF                                                                                                                                                                                          | NF                                                                                              | LUF                                                                                            | LVF |
|             | Modified                                                                                                                                                                                                                                                                      | No No                                                                                                                                                                                          | No                                                                                              | Yes                                                                                            | Yes |
|             | • LUF = 1 i                                                                                                                                                                                                                                                                   | -                                                                                                                                                                                              | adified as follows:<br>ates an underflow co<br>ates an overflow cor                             |                                                                                                |     |
| Pipeline    | This is a sing                                                                                                                                                                                                                                                                | gle-cycle instruction                                                                                                                                                                          |                                                                                                 |                                                                                                |     |
| Example     | <pre>; Calculate<br/>; Ye = Estim<br/>; Ye = Ye*(2<br/>; Ye = Ye*(2<br/>;<br/>_ClalTask1:<br/>MMOV32<br/>MEINVF32<br/>MMPYF32<br/>MMPYF32<br/>MMPYF32<br/>MMOV32<br/>MSUBF32<br/>MMPYF32<br/>MMOV32<br/>MNEGF32<br/>MMPYF32<br/>MMOV32<br/>MNEGF32<br/>MMOV32<br/>MSTOP</pre> | <pre>Mate(1/X) 2.0 - Ye*X) 2.0 - Ye*X) 2.0 - Ye*X) 2.0 MR2, MR1 MR3, MR2, MR1 MR3, #2.0, MR3 MR2, MR2, MR3 MR3, MR2, MR1 MR0, @_Num MR3, #2.0, MR3 MR2, MR2, MR3 MR1, @_Den MR0, MR0, EQ</pre> | <pre>; MR3 = Ye*Den ; MR0 = Num ; MR3 = 2.0 - Ye* ; MR2 = Ye = Ye* ; Reload Den To S</pre>      | imate(1/Den)<br>*Den<br>(2.0 - Ye*Den)<br>*Den<br>(2.0 - Ye*Den)<br>Set Sign<br>Change Sign Of |     |
| See also    | MMPYF32 M<br>MMPYF32 M<br>MMPYF32 M<br>MMPYF32 M                                                                                                                                                                                                                              | 1Rd, MRe, MRf    N<br>1Rd, MRe, MRf    N<br>1Ra, MRb, MRc    N                                                                                                                                 | /ADDF32 MRd, MR<br>IMOV32 MRa, mem<br>IMOV32 mem32, MI<br>/ISUBF32 MRd, MR<br>Re, MRf    MMOV32 | 32<br>Ra<br>e, MRf                                                                             |     |

# MMPYF32 MRa, #16FHi, MRb 32-Bit Floating-Point Multiply

| Operands    |                                                                                                                                                                                                                                     |                                                                    |                                                                    |                                                      |                                                                                |                                                                                                            |   |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---|--|
|             | MRa                                                                                                                                                                                                                                 | CLA                                                                | floating-point de                                                  | stination register (M                                | R0 to MR3)                                                                     |                                                                                                            |   |  |
|             | #16FHi A 16-bit immediate value that represents the upper 16-bits of an IEEE 32-bit fle<br>point value. The low 16-bits of the mantissa are assumed to be all 0.                                                                    |                                                                    |                                                                    |                                                      |                                                                                |                                                                                                            |   |  |
|             | MRc                                                                                                                                                                                                                                 | CLA                                                                | floating-point sou                                                 | urce register (MR0 t                                 | o MR3)                                                                         |                                                                                                            |   |  |
| Opcode      | LSW: IIII IIII IIII IIII<br>MSW: 0111 0111 1000 baaa                                                                                                                                                                                |                                                                    |                                                                    |                                                      |                                                                                |                                                                                                            |   |  |
| Description | Multiply MRb<br>the result of t                                                                                                                                                                                                     |                                                                    |                                                                    | value represent                                      | ed by the immed                                                                | liate operand. Store                                                                                       | е |  |
|             | floating-point<br>most useful f<br>Some examp<br>(0xBFC0000                                                                                                                                                                         | value. Th<br>or represe<br>bles are 2.<br>0). The as<br>ralue -1.5 | e low 16-bits<br>enting constant<br>0 (0x4000000<br>sembler will a | of the mantissants where the lo<br>00), 4.0 (0x4080  | are assumed to<br>west 16-bits of th<br>0000), 0.5 (0x3F<br>nex or float as th | of an IEEE 32-bit<br>be all 0. #16FHi is<br>ne mantissa are 0.<br>7000000), and -1.5<br>e immediate value. | 5 |  |
|             | This instruction                                                                                                                                                                                                                    | on can als                                                         | so be written                                                      | as MMPYF32 M                                         | Ra, MRb, #16FF                                                                 | łi.                                                                                                        |   |  |
| Flores      |                                                                                                                                                                                                                                     |                                                                    |                                                                    |                                                      |                                                                                |                                                                                                            |   |  |
| Flags       |                                                                                                                                                                                                                                     | TF                                                                 |                                                                    | ng flags in the M<br>NF                              | LUF                                                                            | LVF                                                                                                        |   |  |
|             |                                                                                                                                                                                                                                     | No                                                                 | No                                                                 | No                                                   | Yes                                                                            | Yes                                                                                                        |   |  |
|             |                                                                                                                                                                                                                                     | f MMPYF                                                            | 32 generates                                                       | ed as follows:<br>an underflow co<br>an overflow con |                                                                                |                                                                                                            |   |  |
| Pipeline    | This is a sing                                                                                                                                                                                                                      | le-cycle ir                                                        | nstruction.                                                        |                                                      |                                                                                |                                                                                                            |   |  |
| Example 1   | <pre>; Same as example 2 but #16FHi is represented in float<br/>MMOVIZ MR3, #2.0 ; MR3 = 2.0 (0x40000000)<br/>MMPYF32 MR0, #3.0, MR3 ; MR0 = 3.0 * MR3 = 6.0 (0x40C00000)<br/>MMOV32 @_X, MR0 ; Save the result in variable X</pre> |                                                                    |                                                                    |                                                      |                                                                                |                                                                                                            |   |  |
| Example 2   | ; Same as ex<br>MMOVIZ<br>MMPYF32<br>MMOV32                                                                                                                                                                                         | MR3, #2                                                            | .0 ;<br>x4040, MR3 ;                                               |                                                      |                                                                                |                                                                                                            |   |  |



| www      | ti  | com   |  |
|----------|-----|-------|--|
| ** ** ** | .u. | COIII |  |

| Example 3 | <pre>; Given X, M and B are IQ24 numbers:<br/>; X = IQ24(+2.5) = 0x02800000<br/>; M = IQ24(+1.5) = 0x01800000<br/>; B = IQ24(-0.5) = 0xFF800000<br/>;<br/>; Calculate Y = X * M + B<br/>;<br/>;<br/>_ClalTask2:</pre> |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | ;                                                                                                                                                                                                                     |
|           | ; Convert M, X and B from IQ24 to float                                                                                                                                                                               |
|           | MI32TOF32 MRO, $@_M$ ; MRO = 0x4BC00000                                                                                                                                                                               |
|           | MI32TOF32 MR1, @_X ; MR1 = 0x4C200000                                                                                                                                                                                 |
|           | MI32TOF32 MR2, @_B ; MR2 = 0xCB000000                                                                                                                                                                                 |
|           | MMPYF32 MR0, MR0, $\#0x3380$ ; M = $1/(1*2^24)$ * iqm = 1.5 (0x3FC00000)                                                                                                                                              |
|           | MMPYF32 MR1, MR1, $\#0x3380$ ; X = $1/(1*2^24) * iqx = 2.5 (0x40200000)$                                                                                                                                              |
|           | MMPYF32 MR2, MR2, $\#0x3380$ ; B = 1/(1*2^24) * iqb =5 (0xBF000000)                                                                                                                                                   |
|           | MMPYF32 MR3, MR0, MR1 ; M*X                                                                                                                                                                                           |
|           | MADDF32 MR2, MR2, MR3 ; Y=MX+B = 3.25 (0x40500000)                                                                                                                                                                    |
|           | ; Convert Y from float32 to IQ24                                                                                                                                                                                      |
|           | MMPYF32 MR2, MR2, #0x4B80 ; Y * 1*2^24                                                                                                                                                                                |
|           | MF32T0I32 MR2, MR2 ; IQ24(Y) = 0x03400000                                                                                                                                                                             |
|           | MMOV32 @_Y, MR2 ; store result                                                                                                                                                                                        |
|           | MSTOP ; end of task                                                                                                                                                                                                   |
| See also  | MMPYF32 MRa, MRb, #16FHi<br>MMPYF32 MRa, MRb, MRc<br>MMPYF32 MRa, MRb, MRc    MADDF32 MRd, MRe, MRf                                                                                                                   |

### MMPYF32 MRa, MRb, #16FHi 32-Bit Floating-Point Multiply

| Operands    |                                                              |                                                                  |                                                                                    |                                                                       |                                                                                   |                                                                                                              |   |  |
|-------------|--------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|---|--|
|             | MRa                                                          | CLA                                                              | floating-point des                                                                 | stination register (M                                                 | R0 to MR3)                                                                        |                                                                                                              |   |  |
|             | MRb CLA floating-point source register (MR0 to MR3)          |                                                                  |                                                                                    |                                                                       |                                                                                   |                                                                                                              |   |  |
|             | #16FHi                                                       |                                                                  |                                                                                    |                                                                       | the upper 16-bits of<br>sa are assumed to b                                       | an IEEE 32-bit floating-<br>e all 0.                                                                         |   |  |
| Opcode      | LSW: IIII IIII IIII<br>MSW: 0111 0111 1000 baaa              |                                                                  |                                                                                    |                                                                       |                                                                                   |                                                                                                              |   |  |
| Description | Multiply MRb<br>the result of t                              |                                                                  | • •                                                                                | value represent                                                       | ed by the immed                                                                   | liate operand. Store                                                                                         | ; |  |
|             | floating-point<br>most useful f<br>Some examp<br>(0xBFC00000 | value. Th<br>or represe<br>les are 2.<br>0). The as<br>alue -1.5 | e low 16-bits<br>enting constar<br>0 (0x4000000<br>sembler will a<br>can be repres | of the mantissants where the lo<br>00), 4.0 (0x4080                   | a are assumed to<br>west 16-bits of th<br>00000), 0.5 (0x3F<br>nex or float as th | s of an IEEE 32-bit<br>be all 0. #16FHi is<br>ne mantissa are 0.<br>5000000), and -1.5<br>e immediate value. |   |  |
|             | This instruction                                             | on can als                                                       | so be writen a                                                                     | s MMPYF32 M                                                           | Ra, #16FHi, MRI                                                                   | Э.                                                                                                           |   |  |
| Flags       | This instruction                                             | on modifie                                                       | es the followin                                                                    | g flags in the M                                                      | ISTF register:.                                                                   |                                                                                                              |   |  |
|             | Flag                                                         | TF                                                               | ZF                                                                                 | NF                                                                    | LUF                                                                               | LVF                                                                                                          |   |  |
|             | Modified                                                     | No                                                               | No                                                                                 | No                                                                    | Yes                                                                               | Yes                                                                                                          |   |  |
|             | • LUF = 1 if                                                 | f MMPYF                                                          | -                                                                                  | d as follows:<br>an underflow co<br>an overflow cor                   |                                                                                   |                                                                                                              |   |  |
| Pipeline    | This is a sing                                               | le-cycle ii                                                      | nstruction.                                                                        |                                                                       |                                                                                   |                                                                                                              |   |  |
| Example 1   | ;Same as exa<br>MMOVIZ<br>MMPYF32<br>MMOV32                  | MR3, #2                                                          | .0 ; мл<br>.3, #3.0 ; мл                                                           | represented in<br>R3 = 2.0 (0x400<br>R0 = MR3 * 3.0<br>ave the result | 000000)<br>= 6.0 (0x40C000                                                        | 00)                                                                                                          |   |  |
| Example 2   | ;Same as abo<br>MMOVIZ<br>MMPYF32<br>MMOV32                  | MR3, #2                                                          | .0                                                                                 | is represented<br>; MR3 = 2.0 (02<br>; MR0 = MR3 * (                  |                                                                                   | 4000000)                                                                                                     |   |  |



| www | .tı. | com |
|-----|------|-----|

| Example 3 | <pre>; Given X, M and B are IQ24 numbers:<br/>; X = IQ24(+2.5) = 0x02800000<br/>; M = IQ24(+1.5) = 0x01800000<br/>; B = IQ24(-0.5) = 0xFF800000<br/>;<br/>; Calculate Y = X * M + B<br/>;<br/>_ClalTask2:<br/>;</pre> |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | ; Convert M, X and B from IQ24 to float                                                                                                                                                                               |
|           | MI32TOF32 MR0, $@_M$ ; MR0 = 0x4BC00000                                                                                                                                                                               |
|           | MI32TOF32 MR1, @_X ; MR1 = 0x4C200000                                                                                                                                                                                 |
|           | MI32TOF32 MR2, @_B ; MR2 = 0xCB000000                                                                                                                                                                                 |
|           | MMPYF32 MR0, #0x3380, MR0 ; M = 1/(1*2^24) * iqm = 1.5 (0x3FC00000)                                                                                                                                                   |
|           | MMPYF32 MR1, $\#0x3380$ , MR1 ; X = $1/(1*2^24) * iqx = 2.5 (0x40200000)$                                                                                                                                             |
|           | MMPYF32 MR2, $\#0x3380$ , MR2; B = $1/(1*2^{24}) * iqb =5 (0xBF000000)$                                                                                                                                               |
|           | MMPYF32 MR3, MR0, MR1 ; M*X                                                                                                                                                                                           |
|           | MADDF32 MR2, MR2, MR3 ; Y=MX+B = 3.25 (0x40500000)                                                                                                                                                                    |
|           | ; Convert Y from float32 to IQ24                                                                                                                                                                                      |
|           | MMPYF32 MR2, #0x4B80, MR2 ; Y * 1*2^24                                                                                                                                                                                |
|           | MF32TOI32 MR2, MR2 ; IQ24(Y) = 0x03400000                                                                                                                                                                             |
|           | MMOV32 @_Y, MR2 ; store result                                                                                                                                                                                        |
|           | MSTOP ; end of task                                                                                                                                                                                                   |
| See also  | MMPYF32 MRa, #16FHi, MRb<br>MMPYF32 MRa, MRb, MRc                                                                                                                                                                     |

# MMPYF32 MRa, MRb, MRc||MADDF32 MRd, MRe, MRf 32-Bit Floating-Point Multiply with Parallel Add

| Operands                              | MRa                                          |                                                                                      | ating-point destinati<br>annot be the same re | on register for MMP<br>egister as MRd                                    | YF32 (MR0 to MR3) | 1   |
|---------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------|-----------------------------------------------|--------------------------------------------------------------------------|-------------------|-----|
|                                       | MRb                                          | CLA flo                                                                              | ating-point source re                         | egister for MMPYF32                                                      | 2 (MR0 to MR3)    |     |
|                                       | MRc                                          | CLA flo                                                                              | ating-point source re                         | egister for MMPYF32                                                      | 2 (MR0 to MR3)    |     |
|                                       | MRd                                          |                                                                                      | ating-point destinati<br>annot be the same re | ion register for MADE<br>egister as MRa                                  | OF32 (MR0 to MR3) |     |
|                                       | MRe                                          | CLA flo                                                                              | ating-point source re                         | egister for MADDF32                                                      | 2 (MR0 to MR3)    |     |
|                                       | MRf                                          | CLA flo                                                                              | ating-point source re                         | egister for MADDF32                                                      | 2 (MR0 to MR3)    |     |
| Opcode<br>Description<br>Restrictions | MRa = MRb *<br>MRd = MRe +<br>The destinat   | olo oooo ooo<br>contents of t<br><sup>MRc;</sup><br><sup>MRf;</sup><br>tion register | wo floating-poin                              | it registers with p<br>32 and the MADI<br>Rd.                            |                   |     |
| Flags                                 | This instruct                                | ion modifies                                                                         | the following fla                             | ags in the MSTF                                                          | register:         |     |
|                                       | Flag                                         | TF                                                                                   | ZF                                            | NF                                                                       | LUF               | LVF |
|                                       | Modified                                     | No                                                                                   | No                                            | No                                                                       | Yes               | Yes |
| Pipeline                              | <ul> <li>LUF = 1</li> <li>LVF = 1</li> </ul> | if MMPYF32<br>if MMPYF32                                                             | or MADDF32 g                                  | s follows:<br>generates an unc<br>generates an ove<br>e in a single cycl | erflow condition. | 1.  |
|                                       |                                              |                                                                                      |                                               | - •                                                                      |                   |     |



| www.ti | .com |
|--------|------|
|--------|------|

| Example | ; Perform 5 multiply and accumulate operations:                        |
|---------|------------------------------------------------------------------------|
|         | ;<br>; X and Y are 32-bit floating point arrays                        |
|         | ;                                                                      |
|         | ; lst multiply: A = X0 * Y0                                            |
|         | ; 2nd multiply: B = X1 * Y1                                            |
|         | ; 3rd multiply: C = X2 * Y2                                            |
|         | ; 4th multiply: D = X3 * Y3                                            |
|         | ; 5th multiply: $E = X3 * Y3$                                          |
|         | ;                                                                      |
|         | ; Result = $A + B + C + D + E$                                         |
|         | ;                                                                      |
|         | _ClalTask1:                                                            |
|         | MMOVI16 MAR0, #_X ; MAR0 points to X array                             |
|         | MMOVI16 MAR1, #_Y ; MAR1 points to Y array                             |
|         | MNOP ; Delay for MAR0, MAR1 load                                       |
|         | MNOP ; Delay for MAR0, MAR1 load                                       |
|         | ; < MARO valid                                                         |
|         | MMOV32 MR0, *MAR0[2]++ ; MR0 = X0, MAR0 += 2                           |
|         | ; < MAR1 valid                                                         |
|         | MMOV32 MR1, *MAR1[2]++ ; MR1 = Y0, MAR1 += 2                           |
|         | MMPYF32 MR2, MR0, MR1 ; MR2 = A = X0 * Y0                              |
|         | <pre>   MMOV32 MR0, *MAR0[2]++ ; In parallel MR0 = X1, MAR0 += 2</pre> |
|         | MMOV32 MR1, *MAR1[2]++ ; MR1 = Y1, MAR1 += 2                           |
|         | MMPYF32 MR3, MR0, MR1 ; MR3 = B = X1 * Y1                              |
|         | <pre>   MMOV32 MR0, *MAR0[2]++ ; In parallel MR0 = X2, MAR0 += 2</pre> |
|         | MMOV32 MR1, *MAR1[2]++ ; MR1 = Y2, MAR2 += 2                           |
|         | MMACF32 MR3, MR2, MR2, MR0, MR1 ; MR3 = A + B, MR2 = C = X2 * Y2       |
|         | <pre>   MMOV32 MR0, *MAR0[2]++ ; In parallel MR0 = X3</pre>            |
|         | MMOV32 MR1, *MAR1[2]++ ; MR1 = Y3                                      |
|         | MMACF32 MR3, MR2, MR2, MR0, MR1 ; MR3 = (A + B) + C, MR2 = D = X3 * Y3 |
|         | <pre>   MMOV32 MR0, *MAR0 ; In parallel MR0 = X4</pre>                 |
|         | MMOV32 MR1, *MAR1 ; MR1 = Y4                                           |
|         | MMPYF32 MR2, MR0, MR1 ; MR2 = E = X4 * Y4                              |
|         | MADDF32 MR3, MR3, MR2 ; in parallel MR3 = (A + B + C) + D              |
|         | MADDF32 MR3, MR3, MR2 ; MR3 = (A + B + C + D) + E                      |
|         | MMOV32 @_Result, MR3 ; Store the result                                |
|         | MSTOP ; end of task                                                    |
|         |                                                                        |

See also

MMACF32 MR3, MR2, MRd, MRe, MRf || MMOV32 MRa, mem32



#### MMPYF32 MRd, MRe, MRf ||MMOV32 MRa, mem32 32-Bit Floating-Point Multiply with Parallel Move

#### Operands MRd CLA floating-point destination register for the MMPYF32 (MR0 to MR3) MRd cannot be the same register as MRa MRe CLA floating-point source register for the MMPYF32 (MR0 to MR3) MRf CLA floating-point source register for the MMPYF32 (MR0 to MR3) CLA floating-point destination register for the MMOV32 (MR0 to MR3) MRa MRa cannot be the same register as MRd mem32 32-bit memory location accessed using direct or indirect addressing. This will be the source of the MMOV32. Opcode LSW: mmmm mmmm mmmm MSW: 0000 ffee ddaa addr Description Multiply the contents of two floating-point registers and load another. MRd = MRe \* MRf; MRa = [mem32];The destination register for the MMPYF32 and the MMOV32 must be unique. That is, Restrictions MRa cannot be the same register as MRd. This instruction modifies the following flags in the MSTF register:. Flags Flag TF ZF NF LUF LVF Modified Yes Yes No Yes Yes The MSTF register flags are modified as follows: LUF = 1 if MMPYF32 generates an underflow condition. LVF = 1 if MMPYF32 generates an overflow condition. The MMOV32 Instruction will set the NF and ZF flags as follows: NF = MRa(31);ZF = 0; $if(MRa(30:23) == 0) \{ ZF = 1; NF = 0; \}$ **Pipeline** Both MMPYF32 and MMOV32 complete in a single cycle. Example 1 ; Given M1, X1 and B1 are 32-bit floating point ; Calculate Y1 = M1\*X1+B1 ; \_ClalTask1: MMOV32 MR0, @M1 ; Load MR0 with M1 MMOV32 MR1, @X1 ; Load MR1 with X1 MR1, MR1, MR0 ; Multiply M1\*X1 MMPYF32 MMOV32 MR0, @B1 ; and in parallel load MR0 with B1 MR1, MR1, MR0 ; Add M\*X1 to B1 and store in MR1 MADDF32 MMOV32 @Y1, MR1 ; Store the result

MSTOP

; end of task



Instruction Set

| Example 2 | <pre>; Given A, B and C are 32-bit floating-point numbers ; Calculate Y2 = (A * B) ; Y3 = (A * B) * C ; ClalTask2:</pre>                                                                                                                                                                                                          |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | MMOV32 MR0, @A ; Load MR0 with A<br>MMOV32 MR1, @B ; Load MR1 with B<br>MMPYF32 MR1, MR1, MR0 ; Multiply A*B<br>   MMOV32 MR0, @C ; and in parallel load MR0 with C<br>MMPYF32 MR1, MR1, MR0 ; Multiply (A*B) by C<br>   MMOV32 @Y2, MR1 ; and in parallel store A*B<br>MMOV32 @Y3, MR1 ; Store the result<br>MSTOP ; end of task |
| See also  | MMPYF32 MRd, MRe, MRf    MMOV32 mem32, MRa<br>MMACF32 MR3, MR2, MRd, MRe, MRf    MMOV32 MRa, mem32                                                                                                                                                                                                                                |



# MMPYF32 MRd, MRe, MRf ||MMOV32 mem32, MRa 32-Bit Floating-Point Multiply with Parallel Move

| Operands    |                                                    |                                                                                                                  |                                                                                                                                                       |                                      |                          |
|-------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------|
|             | MRd                                                | CLA floating-po                                                                                                  | int destination register for                                                                                                                          | r the MMPYF32 (MRC                   | ) to MR3)                |
|             | MRe                                                | CLA floating-po                                                                                                  | int source register for the                                                                                                                           | MMPYF32 (MR0 to M                    | MR3)                     |
|             | MRf                                                | CLA floating-po                                                                                                  | int source register for the                                                                                                                           | MMPYF32 (MR0 to M                    | MR3)                     |
|             | mem32                                              | 32-bit memory I<br>destination of th                                                                             | ocation accessed using c<br>ine MMOV32.                                                                                                               | direct or indirect addre             | essing. This will be the |
|             | MRa                                                | CLA floating-po                                                                                                  | int source register for the                                                                                                                           | MMOV32 (MR0 to M                     | R3)                      |
| Opcode      | LSW: mmmm mmmm<br>MSW: 0100 ffee                   |                                                                                                                  |                                                                                                                                                       |                                      |                          |
| Description | Multiply the co<br>MRd = MRe * MI<br>[mem32] = MRa | Rf;                                                                                                              | ating-point registers                                                                                                                                 | and move from m                      | nemory to register.      |
| Flags       |                                                    |                                                                                                                  | lowing flags in the M                                                                                                                                 | -                                    |                          |
|             | Flag T                                             |                                                                                                                  | NF                                                                                                                                                    | LUF                                  | LVF                      |
|             | Modified N                                         | o No                                                                                                             | No                                                                                                                                                    | Yes                                  | Yes                      |
|             | The MSTF req                                       | ister flags are m                                                                                                | odified as follows:                                                                                                                                   |                                      |                          |
|             | -                                                  | -                                                                                                                | ates an underflow c                                                                                                                                   | ondition.                            |                          |
|             |                                                    | •                                                                                                                | ates an overflow cor                                                                                                                                  |                                      |                          |
| Pipeline    |                                                    | 0                                                                                                                | complete in a single                                                                                                                                  |                                      |                          |
| Example     | ; Calculate Y                                      | 2 = (A * B)<br>3 = (A * B) * C<br>MR0, @A<br>MR1, @B<br>MR1, MR1, MR0<br>MR0, @C                                 | <pre>; Load MR0 with A ; Load MR1 with B ; Multiply A*B ; and in parallel ; Multiply (A*B) 1 ; and in parallel ; Store the resul; ; end of task</pre> | load MR0 with C<br>by C<br>store A*B |                          |
| See also    | MMPYF32 MR                                         | and the second | /MOV32 MRa, mem<br>IRe, MRf    MMOV32                                                                                                                 |                                      |                          |

# MMPYF32 MRa, MRb, MRc ||MSUBF32 MRd, MRe, MRf 32-Bit Floating-Point Multiply with Parallel Subtract

| Operands     |                            |                                                 |                                                       |                                 |                     |
|--------------|----------------------------|-------------------------------------------------|-------------------------------------------------------|---------------------------------|---------------------|
| ·            | MRa                        |                                                 | -point destination registe<br>be the same register as | er for MMPYF32 (MR0 to MRd      | MR3)                |
|              | MRb                        | CLA floating                                    | -point source register for                            | r MMPYF32 (MR0 to MR3           | 3)                  |
|              | MRc                        | CLA floating                                    | -point source register for                            | r MMPYF32 (MR0 to MR3           | 3)                  |
|              | MRd                        |                                                 | -point destination registe<br>be the same register as | er for MSUBF32 (MR0 to I<br>MRa | MR3)                |
|              | MRe                        | CLA floating                                    | -point source register for                            | r MSUBF32 (MR0 to MR3           | )                   |
|              | MRf                        | CLA floating                                    | -point source register for                            | r MSUBF32 (MR0 to MR3           | )                   |
| Opcode       |                            | fee ddcc bbaa<br>010 0100 0000                  |                                                       |                                 |                     |
| Description  | Multiply the registers.    | contents of two                                 | loating-point registe                                 | ers with parallel subt          | raction of two      |
|              | MRa = MRb *<br>MRd = MRe - |                                                 |                                                       |                                 |                     |
| Restrictions |                            | ion register for t<br>be the same re            |                                                       | he MSUBF32 must I               | be unique. That is, |
| Flags        | This instruct              | ion modifies the                                | following flags in th                                 | e MSTF register:.               |                     |
|              | Flag                       | TF ZF                                           | NF                                                    | LUF                             | LVF                 |
|              | Modified                   | No No                                           | No                                                    | Yes                             | Yes                 |
|              |                            | ogistor flaga ara                               | modified on follows                                   |                                 |                     |
|              |                            |                                                 | modified as follows                                   |                                 |                     |
|              |                            |                                                 | -                                                     | es an underflow cond            |                     |
|              | • LVF = 1                  | if MMPYF32 or I                                 | MSUBF32 generate                                      | s an overflow condit            | ion.                |
| Pipeline     | MMPYF32 a                  | nd MSUBF32 b                                    | oth complete in a si                                  | ngle cycle.                     |                     |
| Example      |                            | 3 and C are 32-<br>Y2 = (A * B)<br>Y3 = (A - B) | oit floating-point                                    | numbers                         |                     |
|              | ;<br>_ClalTask2:           |                                                 |                                                       |                                 |                     |
|              | _OIGIIIADAD<br>MMOV32      | MRO, @A                                         | ; Load MR0 wit                                        | h A                             |                     |
|              | MMOV32                     | MR1, @B                                         | ; Load MR1 with                                       |                                 |                     |
|              | MMPYF32<br>   MSUBF32      |                                                 |                                                       |                                 |                     |
|              | MMOV32                     | @Y2, MR2                                        | ; Store A*B                                           | ICI DUD (A D)                   |                     |
|              | MMOV32                     | @Y3, MR3                                        | ; Store A-B                                           |                                 |                     |
|              | MSTOP                      |                                                 | ; end of task                                         |                                 |                     |
| See also     | MSUBF32 M                  | IRa, MRb, MRc                                   |                                                       |                                 |                     |
|              | MSUBF32 M                  | IRd, MRe, MRf                                   | MMOV32 MRa, m                                         |                                 |                     |
|              | MSUBF32 M                  | IRd, MRe, MRf                                   | MMOV32 mem32                                          | , MRa                           |                     |
|              |                            |                                                 |                                                       |                                 |                     |

# MNEGF32 MRa, MRb{, CNDF} Conditional Negation

# Operands

| Operands              |                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                    |                    |           |
|-----------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------|
|                       | MRa                                                                                                      | CLA floating                                                                                                                                                                                                                                                                                                                                                          | p-point destination register (MR0 to M                                                                                                                             | 1R3)               |           |
|                       | MRb                                                                                                      | CLA floating                                                                                                                                                                                                                                                                                                                                                          | p-point source register (MR0 to MR3)                                                                                                                               |                    |           |
|                       | CNDF                                                                                                     | condition tes                                                                                                                                                                                                                                                                                                                                                         | sted                                                                                                                                                               |                    |           |
| Opcode                |                                                                                                          | 0000 cndf bbaa<br>1010 1000 0000                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                    |                    |           |
| Description           | if (CNDF =<br>else {MRa                                                                                  | == true) {MRa = -<br>= MRb; }                                                                                                                                                                                                                                                                                                                                         | MRb; }                                                                                                                                                             |                    |           |
|                       | CNDF is a                                                                                                | ne of the following                                                                                                                                                                                                                                                                                                                                                   | g conditions:                                                                                                                                                      |                    |           |
|                       | Encode <sup>(5)</sup>                                                                                    | CNDF                                                                                                                                                                                                                                                                                                                                                                  | Description                                                                                                                                                        | MSTF Flags         | Tested    |
|                       | 0000                                                                                                     | NEQ                                                                                                                                                                                                                                                                                                                                                                   | Not equal to zero                                                                                                                                                  | ZF == 0            |           |
|                       | 0001                                                                                                     | EQ                                                                                                                                                                                                                                                                                                                                                                    | Equal to zero                                                                                                                                                      | ZF == 1            |           |
|                       | 0010                                                                                                     | GT                                                                                                                                                                                                                                                                                                                                                                    | Greater than zero                                                                                                                                                  | ZF == 0 AND        | NF == 0   |
|                       | 0011                                                                                                     | GEQ                                                                                                                                                                                                                                                                                                                                                                   | Greater than or equal to zero                                                                                                                                      | NF == 0            |           |
|                       | 0100                                                                                                     | LT                                                                                                                                                                                                                                                                                                                                                                    | Less than zero                                                                                                                                                     | NF == 1            |           |
|                       | 0101                                                                                                     | LEQ                                                                                                                                                                                                                                                                                                                                                                   | Less than or equal to zero                                                                                                                                         | ZF == 1 OR N       | IF == 1   |
|                       | 1010                                                                                                     | TF                                                                                                                                                                                                                                                                                                                                                                    | Test flag set                                                                                                                                                      | TF == 1            |           |
|                       | 1011                                                                                                     | NTF                                                                                                                                                                                                                                                                                                                                                                   | Test flag not set                                                                                                                                                  | TF == 0            |           |
|                       | 1100                                                                                                     | LU                                                                                                                                                                                                                                                                                                                                                                    | Latched underflow                                                                                                                                                  | LUF == 1           |           |
|                       | 1101                                                                                                     | LV                                                                                                                                                                                                                                                                                                                                                                    | Latched overflow                                                                                                                                                   | LVF == 1           |           |
|                       | 1110                                                                                                     | UNC                                                                                                                                                                                                                                                                                                                                                                   | Unconditional                                                                                                                                                      | None               |           |
|                       | 1111                                                                                                     | UNCF <sup>(6)</sup>                                                                                                                                                                                                                                                                                                                                                   | Unconditional with flag modification                                                                                                                               | None               |           |
| Flags                 | <sup>(6)</sup> This is the modif                                                                         | ied when a conditional                                                                                                                                                                                                                                                                                                                                                | t.<br>no CNDF field is specified. This cond<br>I operation is executed. All other cond<br>following flags in the MSTF r                                            | ditions will not m |           |
|                       | Flag<br>Modified                                                                                         | TF         ZF           No         Ye                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                    | LUF<br>No          | LVF<br>No |
| Pipeline              | <b>Flag</b><br>Modified                                                                                  | No Ye                                                                                                                                                                                                                                                                                                                                                                 | es Yes                                                                                                                                                             |                    | · · · · · |
| Pipeline              | <b>Flag</b><br>Modified                                                                                  |                                                                                                                                                                                                                                                                                                                                                                       | es Yes                                                                                                                                                             |                    | · · · · · |
| Pipeline<br>Example 1 | Flag<br>Modified<br>This is a s                                                                          | No Ye                                                                                                                                                                                                                                                                                                                                                                 | es Yes                                                                                                                                                             |                    | · · · · · |
| -                     | Flag<br>Modified<br>This is a s                                                                          | No Ye<br>ingle-cycle instruc<br>e basic operation<br>IZ MR0, #5.0                                                                                                                                                                                                                                                                                                     | es Yes                                                                                                                                                             | No                 | · · · · · |
| -                     | Flag<br>Modified<br>This is a s<br>; Show the<br>;<br>MMOVI<br>MMOVI                                     | No Ye<br>ingle-cycle instruc<br>basic operation<br>IZ MR0, #5.0<br>IZ MR1, #4.0<br>IZ MR2, #-1.5                                                                                                                                                                                                                                                                      | es Yes<br>tion.<br>of MNEGF32<br>; MR0 = 5.0 (0x40A00000<br>; MR1 = 4.0 (0x4080000<br>; MR2 = -1.5 (0xBFC0000                                                      | No<br>)<br>)       | · · · · · |
| -                     | Flag<br>Modified<br>This is a s<br>; Show the<br>;<br>MMOVI<br>MMOVI<br>MMOVI<br>MMOVI                   | No Ye<br>ingle-cycle instruc<br>basic operation<br>IZ MR0, #5.0<br>IZ MR1, #4.0<br>IZ MR2, #-1.5<br>F32 MR3, MR1, M                                                                                                                                                                                                                                                   | es Yes<br>tion.<br>. of MNEGF32<br>; MR0 = 5.0 (0x40A00000<br>; MR1 = 4.0 (0x40800000<br>; MR2 = -1.5 (0xBFC0000<br>R2 ; MR3 = -6.0                                | No<br>)<br>)       | · · · · · |
| -                     | Flag<br>Modified<br>This is a s<br>; Show the<br>;<br>MMOVI<br>MMOVI                                     | No Ye<br>ingle-cycle instruct<br>basic operation<br>IZ MR0, #5.0<br>IZ MR1, #4.0<br>IZ MR2, #-1.5<br>F32 MR3, MR1, M<br>F32 MR0, MR0, M                                                                                                                                                                                                                               | es Yes<br>tion.<br>. of MNEGF32<br>; MR0 = 5.0 (0x40A00000<br>; MR1 = 4.0 (0x40800000<br>; MR2 = -1.5 (0xBFC0000<br>R2 ; MR3 = -6.0                                | No<br>)<br>)       | · · · · · |
| -                     | Flag<br>Modified<br>This is a s<br>; show the<br>;<br>MMOVI<br>MMOVI<br>MMOVI<br>MMPYE<br>MMPYE          | No         Ye           ingle-cycle instruct         instruct           e basic operation         12           IZ         MR0, #5.0           IZ         MR1, #4.0           IZ         MR2, #-1.5           F32         MR3, MR1, M           F32         MR0, MR0, M           IZ         MR1, #0.0                                                                 | es Yes<br>tion.<br>. of MNEGF32<br>; MR0 = 5.0 (0x40A00000<br>; MR1 = 4.0 (0x40800000<br>; MR2 = -1.5 (0xBFC0000<br>R2 ; MR3 = -6.0                                | No<br>)<br>)       | · · · · · |
| -                     | Flag<br>Modified<br>This is a s<br>; show the<br>;<br>MMOVI<br>MMOVI<br>MMOVI<br>MMPYE<br>MMPYE<br>MMOVI | No         Ye           ingle-cycle instruct         instruct           e basic operation         12           IZ         MR0, #5.0           IZ         MR1, #4.0           IZ         MR2, #-1.5           F32         MR3, MR1, M           IZ         MR0, MR0, M           IZ         MR1, #0.0           F32         MR3, MR1           F32         MR3, MR3, L | es Yes<br>tion.<br>. of MNEGF32<br>; MR0 = 5.0 (0x40A00000<br>; MR1 = 4.0 (0x40800000<br>; MR2 = -1.5 (0xBFC0000<br>R2 ; MR3 = -6.0<br>R1 ; MR0 = 20.0<br>; NF = 1 | No<br>)<br>)       | · · · · · |

MNEGF32 MR0, MR0, GEQ ; if NF = 0, MR0 = -20.0



| www.ti.con | n |
|------------|---|
| Example    | 2 |

| : Cal  | culate Num/Der | using a New | wton-Raphson algorithum for 1/Den   |
|--------|----------------|-------------|-------------------------------------|
|        |                | -           | webii Kapiison aigorrenam ior i/ben |
|        | = Estimate(1/2 | ,           |                                     |
| ; Ye = | = Ye*(2.0 - Ye | e*X)        |                                     |
| ; Ye = | = Ye*(2.0 - Ye | e*X)        |                                     |
| ;      |                |             |                                     |
| _Cla1  | Task1:         |             |                                     |
| MI     | MOV32 MR1,     | @_Den ;     | ; MR1 = Den                         |
| MI     | EINVF32 MR2,   | MR1 ;       | ; MR2 = Ye = Estimate(1/Den)        |
| MI     | MPYF32 MR3,    | MR2, MR1 ;  | ; MR3 = Ye*Den                      |
| MS     | SUBF32 MR3,    | #2.0, MR3 ; | ; MR3 = 2.0 - Ye*Den                |
| MI     | MPYF32 MR2,    | MR2, MR3 ;  | ; MR2 = Ye = Ye*(2.0 - Ye*Den)      |
| M      | MPYF32 MR3,    | MR2, MR1 ;  | ; MR3 = Ye*Den                      |
| MI     | MOV32 MR0,     | @_Num ;     | ; MRO = Num                         |
| MS     | SUBF32 MR3,    | #2.0, MR3 ; | ; MR3 = 2.0 - Ye*Den                |
| M      | MPYF32 MR2,    | MR2, MR3 ;  | ; MR2 = Ye = Ye*(2.0 - Ye*Den)      |
| MI     | MOV32 MR1,     | @_Den ;     | ; Reload Den To Set Sign            |
| MI     | NEGF32 MR0,    | MRO, EQ ;   | ; if(Den == 0.0) Change Sign Of Num |
| M      | MPYF32 MR0,    | MR2, MR0 ;  | ; MRO = Y = Ye*Num                  |
| M      | MOV32 @_Des    | st, MRO ;   | ; Store result                      |
| MS     | STOP           | ;           | ; end of task                       |
|        |                |             |                                     |

See also

MABSF32 MRa, MRb



| INOP       | No Operati                                                                                                                                                                                        | on                                                                                  |                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| perands    |                                                                                                                                                                                                   |                                                                                     |                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |
|            | none                                                                                                                                                                                              | This                                                                                | s instruction doe                                                                    | es not have any opera                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | nds                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |
| pcode      | LSW: 0000 0<br>MSW: 0111 1                                                                                                                                                                        |                                                                                     |                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |
| escription |                                                                                                                                                                                                   |                                                                                     | uction is use<br>vailable to fil                                                     | d to fill required p<br>the slots.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ipeline delay slo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ts when other |
| lags       | This instruct                                                                                                                                                                                     | tion does                                                                           | not modify fl                                                                        | ags in the MSTF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               |
|            | Flag                                                                                                                                                                                              | TF                                                                                  | ZF                                                                                   | NF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | LUF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | LVF           |
|            | Modified                                                                                                                                                                                          | No                                                                                  | No                                                                                   | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | No            |
| xample     | ; Find the<br>; and store<br>;                                                                                                                                                                    | maximum v<br>it in Re                                                               | alue in an                                                                           | ing-point values<br>array X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |
| xample     | ; Find the                                                                                                                                                                                        | maximum v<br>it in Re                                                               | ralue in an .<br>esult                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTaskl:<br>MMOVI16<br>MUI16TO                                                                                                                               | maximum v<br>it in Re                                                               | value in an sesult<br>#_X                                                            | ; Start address<br>; Length of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTask1:<br>MMOVI16<br>MUI16TO<br>MNOP                                                                                                                       | maximum v<br>it in Re<br>MAR1,                                                      | value in an sesult<br>#_X                                                            | ; Start address<br>; Length of the<br>; delay for MAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTaskl:<br>MMOVI16<br>MUI16TO                                                                                                                               | maximum v<br>it in Re<br>MAR1,<br>F32 MR0,                                          | value in an sesult<br>#_X                                                            | ; Start address<br>; Length of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTaskl:<br>MMOVI16<br>MUI16TO<br>MNOP<br>MNOP                                                                                                               | maximum v<br>it in Re<br>MAR1,<br>F32 MR0,                                          | ralue in an soult<br>#_X<br>@_len                                                    | ; Start address<br>; Length of the<br>; delay for MAR<br>; delay for MAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTaskl:<br>MMOVI16<br>MUI16TO<br>MNOP<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32                                                                                   | maximum v<br>it in Re<br>MAR1,<br>F32 MR0,<br>MR1,<br>MR2,                          | <pre>ralue in an sult #_X @_len *MAR1[2]++ *MAR1[2]++</pre>                          | <pre>; Start address ; Length of the ; delay for MAR: ; delay for MAR: ; MR1 = X0 ; MR2 = next element ; MR2 = next element; max = 100; max = 1</pre> | l load<br>l load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTaskl:<br>MMOVI16<br>MUI16TO<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32<br>MMAXF32                                                                                | maximum v<br>it in Re<br>MAR1,<br>F32 MR0,<br>MR1,<br>MR2,<br>MR1,                  | <pre>ralue in an sult #_X @_len *MAR1[2]++ *MAR1[2]++ MR2</pre>                      | <pre>; Start address<br/>; Length of the<br/>; delay for MAR<br/>; delay for MAR<br/>; MR1 = X0<br/>; MR2 = next ele<br/>; MR1 = MAX(MR1</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | l load<br>l load<br>ement<br>, MR2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTaskl:<br>MMOVI16<br>MUI16TO<br>MNOP<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32                                                                                   | maximum v<br>it in Re<br>MAR1,<br>F32 MR0,<br>MR1,<br>MR2,<br>MR1,<br>MR0,          | <pre>ralue in an sult #_X @_len *MAR1[2]++ *MAR1[2]++ MR2 MR0, #-1.0</pre>           | <pre>; Start address<br/>; Length of the<br/>; delay for MAR<br/>; delay for MAR<br/>; MR1 = X0<br/>; MR2 = next ele<br/>; MR1 = MAX(MR1<br/>; Decrement the</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | l load<br>l load<br>ement<br>MR2)<br>counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTask1:<br>MMOVI16<br>MU116TO<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32<br>MMAXF32<br>MADF32                                                                      | maximum v<br>it in Re<br>MAR1,<br>F32 MR0,<br>MR1,<br>MR2,<br>MR1,<br>MR0,          | <pre>ralue in an sult #_X @_len *MAR1[2]++ *MAR1[2]++ MR2 MR0, #-1.0</pre>           | <pre>; Start address<br/>; Length of the<br/>; delay for MAR<br/>; delay for MAR<br/>; MR1 = X0<br/>; MR2 = next ele<br/>; MR1 = MAX(MR1</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | l load<br>l load<br>ement<br>MR2)<br>counter<br>gs for MBCNDD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTask1:<br>MMOVI16<br>MU116TO<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32<br>LOOP<br>MMOV32<br>MAAXF32<br>MADDF32<br>MCMPF32<br>MNOP<br>MNOP                        | maximum v<br>it in Re<br>MAR1,<br>F32 MR0,<br>MR1,<br>MR2,<br>MR1,<br>MR0,          | <pre>ralue in an sult #_X @_len *MAR1[2]++ *MAR1[2]++ MR2 MR0, #-1.0</pre>           | <pre>; Start address<br/>; Length of the<br/>; delay for MAR:<br/>; delay for MAR:<br/>; MR1 = X0<br/>; MR2 = next ele<br/>; MR1 = MAX(MR1<br/>; Decrement the<br/>; Set/clear flag<br/>; Too late to an<br/>; Too late to an</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ement<br>MR2)<br>counter<br>gs for MBCNDD<br>Efect MBCNDD<br>Efect MBCNDD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTask1:<br>MMOVI16<br>MUI16TO<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32<br>LOOP<br>MMOV32<br>MADF32<br>MADF32<br>MCMPF32<br>MNOP<br>MNOP<br>MNOP                  | maximum v<br>it in Re<br>MAR1,<br>F32 MR0,<br>MR1,<br>MR2,<br>MR1,<br>MR0,<br>MR0 # | <pre>ralue in an sult #_X @_len *MAR1[2]++ *MAR1[2]++ MR2 MR0, #-1.0 0.0</pre>       | <pre>; Start address<br/>; Length of the<br/>; delay for MAR:<br/>; delay for MAR:<br/>; MR1 = X0<br/>; MR2 = next ele<br/>; MR1 = MAX(MR1<br/>; Decrement the<br/>; Set/clear flag<br/>; Too late to an<br/>; Too late to an<br/>; Too late to an<br/>; Too late to an</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ement<br>MR2)<br>counter<br>gs for MBCNDD<br>Efect MBCNDD<br>Efect MBCNDD<br>Efect MBCNDD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTask1:<br>MMOVI16<br>MU116TO<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32<br>LOOP<br>MMOV32<br>MADF32<br>MADDF32<br>MCMPF32<br>MNOP<br>MNOP<br>MNOP<br>MNOP<br>MNOP | <pre>maximum v it in Re MAR1, F32 MR0, MR1, MR2, MR1, MR0, MR0 # LOOP,</pre>        | <pre>ralue in an . sult #_X @_len *MAR1[2]++ *MAR1[2]++ MR2 MR0, #-1.0 0.0 NEQ</pre> | <pre>; Start address<br/>; Length of the<br/>; delay for MAR:<br/>; delay for MAR:<br/>; MR1 = X0<br/>; MR2 = next ele<br/>; MR1 = MAX(MR1<br/>; Decrement the<br/>; Set/clear flag<br/>; Too late to an<br/>; Too late to an</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ement<br>( MR2)<br>counter<br>gs for MBCNDD<br>Efect MBCNDD<br>Efect MBCNDD<br>Efect MBCNDD<br>equal to zero                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTask1:<br>MMOVI16<br>MUI16TO<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32<br>LOOP<br>MMOV32<br>MADF32<br>MADF32<br>MCMPF32<br>MNOP<br>MNOP<br>MNOP                  | <pre>maximum v it in Re MAR1, F32 MR0, MR1, MR2, MR1, MR0, MR0 # LOOP,</pre>        | <pre>ralue in an sult #_X @_len *MAR1[2]++ *MAR1[2]++ MR2 MR0, #-1.0 0.0</pre>       | <pre>; Start address<br/>; Length of the<br/>; delay for MAR:<br/>; delay for MAR:<br/>; MR1 = X0<br/>; MR2 = next ele<br/>; MR1 = MAX(MR1<br/>; Decrement the<br/>; Set/clear flag<br/>; Too late to an<br/>; Too late to an<br/>; Too late to an<br/>; Too late to an</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ement<br>( ) MR2)<br>( ) Counter<br>( ) MR2)<br>( ) Counter<br>( ) S for MBCNDD<br>( ) S for                                                                                                                                                                                                | STOP          |
| xample     | ; Find the<br>; and store<br>;<br>_ClalTask1:<br>MMOVI16<br>MU116TO<br>MNOP<br>MMOV32<br>LOOP<br>MMOV32<br>MMAXF32<br>MADDF32<br>MCMPF32<br>MNOP<br>MNOP<br>MNOP<br>MNOP<br>MNOP<br>MNOP<br>MNOP  | <pre>maximum v it in Re MAR1, F32 MR0, MR1, MR2, MR1, MR0, MR0 # LOOP,</pre>        | <pre>ralue in an . sult #_X @_len *MAR1[2]++ *MAR1[2]++ MR2 MR0, #-1.0 0.0 NEQ</pre> | <pre>; Start address<br/>; Length of the<br/>; delay for MAR:<br/>; delay for MAR:<br/>; delay for MAR:<br/>; MR1 = X0<br/>; MR2 = next ele<br/>; MR1 = MAX(MR1<br/>; Decrement the<br/>; Set/clear flag<br/>; Too late to an<br/>; Always executed</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ement<br>( load<br>( load<br>( MR2)<br>( counter<br>gs for MBCNDD<br>( fect MBCNDD<br>( fect MBCNDD<br>( equal to zero<br>( counter)<br>( counter)<br>( for MBCNDD<br>( counter)<br>( |               |

See also

# MOR32 MRa, MRb, MRc Bitwise OR

| Operands    |                                                              |                                     |                       |                                                       |               |     |  |  |  |
|-------------|--------------------------------------------------------------|-------------------------------------|-----------------------|-------------------------------------------------------|---------------|-----|--|--|--|
|             | MRa                                                          | CL                                  | A floating-point de   | stination register (M                                 | R0 to MR3)    |     |  |  |  |
|             | MRb                                                          | CL                                  | A floating-point sou  | urce register (MR0 to                                 | o MR3)        |     |  |  |  |
|             | MRc                                                          | CL                                  | A floating-point sou  | urce register (MR0 to                                 | o MR3)        |     |  |  |  |
| Opcode      |                                                              | 0 0000 00cc<br>1 1100 1000          |                       |                                                       |               |     |  |  |  |
| Description |                                                              | <pre>DR of MRb w 0) = MARb(31</pre> | vith MRc.             | :0);                                                  |               |     |  |  |  |
| Flags       | This inst                                                    | ruction modif                       | ies the followir      | ng flags in the M                                     | STF register: |     |  |  |  |
|             | Flag                                                         | TF                                  | ZF                    | NF                                                    | LUF           | LVF |  |  |  |
|             | Modified                                                     | No                                  | Yes                   | Yes                                                   | No            | No  |  |  |  |
| Pipeline    |                                                              | single-cycle                        | . ,                   |                                                       |               |     |  |  |  |
| -           |                                                              | 1:0) == 0) { single-cycle           | . ,                   |                                                       |               |     |  |  |  |
| Example     | MMOVIZ MRO, #0x5555; MRO = 0x5555AAAA<br>MMOVXI MRO, #0xAAAA |                                     |                       |                                                       |               |     |  |  |  |
|             | MMOVIZ<br>MMOVXI                                             | MR1, #0x54<br>MR1, #0xFE            | 432 ; MR1 = 0x<br>EDC | 5432FEDC                                              |               |     |  |  |  |
|             |                                                              |                                     | ; 0101 OR             | $\begin{array}{rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr$  |               |     |  |  |  |
|             |                                                              |                                     | ; 1010 OR             | 0010 = 0111 (7)<br>1111 = 1111 (F)<br>1110 = 1110 (E) |               |     |  |  |  |
|             | MOR32 MR                                                     | 2, MR1, MR0                         |                       | 1101 = 1111 (F)<br>1100 = 1110 (E)<br>5555FEFE        |               |     |  |  |  |
| See also    |                                                              | 2 MRa, MRb,<br>2 MRa, MRb,          |                       |                                                       |               |     |  |  |  |



# MRCNDD {CNDF} Return Conditional Delayed

#### Operands

 
 CNDF
 optional condition.

 Opcode
 Lsw: 0000 0000 0000 0000 Msw: 0111 1001 1010 cndf

**Description** If the specified condition is true, then the RPC field of MSTF is loaded into MPC and fetching continues from that location. Otherwise program fetches will continue without the return.

Please refer to the pipeline section for important information regarding this instruction. if (CNDF == TRUE) MPC = RPC;

# CNDF is one of the following conditions:

| Encode (7) | CNDF                | Description                          | MSTF Flags Tested   |
|------------|---------------------|--------------------------------------|---------------------|
| 0000       | NEQ                 | Not equal to zero                    | ZF == 0             |
| 0001       | EQ                  | Equal to zero                        | ZF == 1             |
| 0010       | GT                  | Greater than zero                    | ZF == 0 AND NF == 0 |
| 0011       | GEQ                 | Greater than or equal to zero        | NF == 0             |
| 0100       | LT                  | Less than zero                       | NF == 1             |
| 0101       | LEQ                 | Less than or equal to zero           | ZF == 1 OR NF == 1  |
| 1010       | TF                  | Test flag set                        | TF == 1             |
| 1011       | NTF                 | Test flag not set                    | TF == 0             |
| 1100       | LU                  | Latched underflow                    | LUF == 1            |
| 1101       | LV                  | Latched overflow                     | LVF == 1            |
| 1110       | UNC                 | Unconditional                        | None                |
| 1111       | UNCF <sup>(8)</sup> | Unconditional with flag modification | None                |

<sup>(7)</sup> Values not shown are reserved.

<sup>(8)</sup> This is the default operation if no CNDF field is specified. This condition will allow the ZF and NF flags to be modified when a conditional operation is executed. All other conditions will not modify these flags.

Flags

#### This instruction does not modify flags in the MSTF register.

| Flag     | TF | ZF | NF | LUF | LVF |  |
|----------|----|----|----|-----|-----|--|
| Modified | No | No | No | No  | No  |  |

```
www.ti.com
                                                                                               Instruction Set
Pipeline
                       The MRCNDD instruction by itself is a single-cycle instruction. As shown in Table 8-31,
                       for each return 6 instruction slots are executed; three before the return instruction (d5-
                       d7) and three after the return instruction (d8-d10). The total number of cycles for a return
                       taken or not taken depends on the usage of these slots. That is, the number of cycles
                       depends on how many slots are filled with a MNOP as well as which slots are filled. The
                       effective number of cycles for a return can, therefore, range from 1 to 7 cycles. The
                       number of cycles for a return taken may not be the same as for a return not taken.
                       Referring to the following code fragment and the pipeline diagrams in Table 8-31 and
                       Table 8-32, the instructions before and after MRCNDD have the following properties:
                       ;
                       ;
                       <Instruction 1> ; Il Last instruction that can affect flags for
                                         ; the MCCNDD operation
                       <Instruction 2>
                                        ; I2 Cannot be stop, branch, call or return
                                        ; I3 Cannot be stop, branch, call or return
                       <Instruction 3>
                       <Instruction 4>
                                        ; I4 Cannot be stop, branch, call or return
                       MCCNDD _func, NEQ ; Call to func if not eqal to zero
                                          ; Three instructions after MCCNDD are always
                                          ; executed whether the call is taken or not
                       <Instruction 5> ; I5 Cannot be stop, branch, call or return
                       <Instruction 6> ; I6 Cannot be stop, branch, call or return
                       <Instruction 7>
                                        ; I7 Cannot be stop, branch, call or return
                       <Instruction 8>
                                          ; 18 The address of this instruction is saved
                                          ; in the RPC field of the MSTF register.
                                          ; Upon return this value is loaded into MPC
                                          ; and fetching continues from this point.
                                          ; 19
                       <Instruction 9>
                       <Instruction 10> ; I10
                       . . . .
                       . . . .
                       _func:
                       <Destination 1>
                                        ; dl Can be any instruction
                       <Destination 2>
                                          ; d2
                       <Destination 3>
                                          ; d3
                       <Destination 4>
                                          ; d4 Last instruction that can affect flags for
                                          ; the MRCNDD operation
                       <Destination 5> ; d5 Cannot be stop, branch, call or return
                       <Destination 6> ; d6 Cannot be stop, branch, call or return
                       <Destination 7> ; d7 Cannot be stop, branch, call or return
                                          ; Return to <Instruction 8> if not equal to zero
                       MRCNDD, NEO
                                          ; Three instructions after MRCNDD are always
                                          ; executed whether the return is taken or not
                       <Destination 8>
                                          ; d8 Cannot be stop, branch, call or return
                       <Destination 9>
                                          ; d9 Cannot be stop, branch, call or return
                       <Destination 10> ; d10 Cannot be stop, branch, call or return
                       <Destination 11> ; d11
                       <Destination 12> ; d12
                       . . . .
                       . . . .
                       MSTOP
                       . . . .
                         d4
                       •

    d4 is the last instruction that can effect the CNDF flags for the MRCNDD

                             instruction. The CNDF flags are tested in the D2 phase of the pipeline. That is, a
```

- decision is made whether to return or not when MRCNDD is in the D2 phase.
  There are no restrictions on the type of instruction for d4.
- d5, d6 and d7
  - The three instructions proceeding MRCNDD can change MSTF flags but will have no effect on whether the MRCNDD instruction makes the return or not. This is



because the flag modification will occur after the D2 phase of the MRCNDD instruction.

- These instructions must not be the following: MSTOP, MDEBUGSTOP, MBCNDD, MCCNDD or MRCNDD.
- d8, d9 and d10
  - The three instructions following MRCNDD are always executed irrespective of whether the return is taken or not.
  - These instructions must not be the following: MSTOP, MDEBUGSTOP, MBCNDD, MCCNDD or MRCNDD.

| Instruction | F1     | F2     | D1     | D2     | R1  | R2  | Е   | w |
|-------------|--------|--------|--------|--------|-----|-----|-----|---|
| d4          | d4     | d3     | d2     | d1     | 17  | 16  | 15  |   |
| d5          | d5     | d4     | d3     | d2     | d1  | 17  | 16  |   |
| d6          | d6     | d5     | d4     | d3     | d2  | d1  | i7  |   |
| d7          | d7     | d6     | d5     | d4     | d3  | d2  | d1  |   |
| MRCNDD      | MRCNDD | d7     | d6     | d5     | d4  | d3  | d2  |   |
| d8          | d8     | MRCNDD | d7     | d6     | d5  | d4  | d3  |   |
| d9          | d9     | d8     | MRCNDD | d7     | d6  | d5  | d4  |   |
| d10         | d10    | d9     | d8     | MRCNDD | d7  | d6  | d5  |   |
| d11         | d11    | d10    | d9     | d8     | -   | d7  | d6  |   |
| d12         | d12    | d11    | d10    | d9     | d8  | -   | d7  |   |
| etc         |        | d12    | d11    | d10    | d9  | d8  | -   |   |
|             |        |        | d12    | d11    | d10 | d9  | d8  |   |
|             |        |        |        | d12    | d11 | d10 | d9  |   |
|             |        |        |        |        | d12 | d11 | d10 |   |
|             |        |        |        |        |     | d12 | d11 |   |
|             |        |        |        |        |     |     | d12 |   |

| Instruction | F1     | F2     | D1     | D2     | R1  | R2  | E   | w |
|-------------|--------|--------|--------|--------|-----|-----|-----|---|
| d4          | d4     | d3     | d2     | d1     | 17  | 16  | 15  |   |
| d5          | d5     | d4     | d3     | d2     | d1  | 17  | 16  |   |
| d6          | d6     | d5     | d4     | d3     | d2  | d1  | i7  |   |
| d7          | d7     | d6     | d5     | d4     | d3  | d2  | d1  |   |
| MRCNDD      | MRCNDD | d7     | d6     | d5     | d4  | d3  | d2  |   |
| d8          | d8     | MRCNDD | d7     | d6     | d5  | d4  | d3  |   |
| d9          | d9     | d8     | MRCNDD | d7     | d6  | d5  | d4  |   |
| d10         | d10    | d9     | d8     | MRCNDD | d7  | d6  | d5  |   |
| 18          | 18     | d10    | d9     | d8     | -   | d7  | d6  |   |
| 19          | 19     | 18     | d10    | d9     | d8  | -   | d7  |   |
| 110         | 110    | 19     | 18     | d10    | d9  | d8  | -   |   |
| etc         |        | 110    | 19     | 18     | d10 | d9  | d8  |   |
|             |        |        | l10    | 19     | 18  | d10 | d9  |   |
|             |        |        |        | 110    | 19  | 18  | d10 |   |
|             |        |        |        |        | l10 | 19  | 18  |   |
|             |        |        |        |        |     | 110 | 19  |   |
|             |        |        |        |        |     |     | I10 |   |

### Table 8-32. Pipeline Activity For MRCNDD, Return Taken



| www.ti.com |                                                                                               | Instruction Set |
|------------|-----------------------------------------------------------------------------------------------|-----------------|
| Example    | ;                                                                                             |                 |
| See also   | MBCNDD #16BitDest, CNDF<br>MCCNDD 16BitDest, CNDF<br>MMOV32 mem32, MSTF<br>MMOV32 MSTF, mem32 |                 |



# MSETFLG FLAG, VALUE Set or Clear Selected Floating-Point Status Flags

| Operands    |                                                                                                                                                           |                                                                         |                                    |                               |                             |                                    |                                                           |                         |         |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------|-------------------------------|-----------------------------|------------------------------------|-----------------------------------------------------------|-------------------------|---------|--|--|
|             | FLAG                                                                                                                                                      | FLAG 8 bit mask indicating which floating-point status flags to change. |                                    |                               |                             |                                    |                                                           |                         |         |  |  |
|             | VALUE                                                                                                                                                     | 8                                                                       | 8 bit mask in                      | dicating the                  | flag value; C               | ) or 1.                            |                                                           |                         |         |  |  |
| Opcode      | LSW: FFFF<br>MSW: 0111                                                                                                                                    | FFFF VVV<br>1001 110                                                    |                                    |                               |                             |                                    |                                                           |                         |         |  |  |
| Description | the MSTF changed.                                                                                                                                         | register.<br>That is, if<br>not be mo                                   | The FLAC<br>a FLAG I<br>dified. Th | G field is a<br>bit is set to | an 11-bit v<br>o 1 it indic | alue that<br>ates that<br>FLAG fie | floating-po<br>indicates w<br>flag will be<br>eld is show | vhich flags<br>changed; | will be |  |  |
|             | reserved                                                                                                                                                  | RNDF32                                                                  | TF                                 | reserved                      | reserved                    | ZF                                 | NF                                                        | LUF                     | LVF     |  |  |
|             | 8                                                                                                                                                         | 7                                                                       | 6                                  | 5                             | 4                           | 3                                  | 2                                                         | 1                       | 0       |  |  |
| Flags       | The VALUE field indicates the value the flag should be set to; 0 or 1.This instruction modifies the following flags in the MSTF register:FlagTFZFNFLUFLVF |                                                                         |                                    |                               |                             |                                    |                                                           |                         |         |  |  |
|             | Modified                                                                                                                                                  | Yes                                                                     | Ye                                 | S                             | Yes                         |                                    | Yes                                                       | Yes                     |         |  |  |
|             | Any flag of modified                                                                                                                                      |                                                                         |                                    |                               | ction. The                  | MEALLC                             | W and RP                                                  | C fields ca             | nnot be |  |  |
| Pipeline    | This is a s                                                                                                                                               | single-cyc                                                              | le instruct                        | tion.                         |                             |                                    |                                                           |                         |         |  |  |
| Example     | MSTFLG                                                                                                                                                    | operation                                                               | as shown                           | n below:                      |                             |                                    | _AG=VALU                                                  | -                       | or the  |  |  |
|             | MSETFLG                                                                                                                                                   | RNDF32=0,                                                               | TF=0, NF                           | F=1; FLAG                     | = 1100010                   | )0; VALUE                          | = 00XXX1X                                                 | X;                      |         |  |  |
| See also    | MMOV32<br>MMOV32                                                                                                                                          |                                                                         |                                    |                               |                             |                                    |                                                           |                         |         |  |  |



| www.ti.com   |                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                 |                                                         |                                          | Instruction Se                                                                               |  |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------|--|--|
| MSTOP        | Stop Task                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                 |                                                         |                                          |                                                                                              |  |  |
| Operands     |                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                 |                                                         |                                          |                                                                                              |  |  |
|              | none                                                                                                                                                                                                                                                                                                                                                                              | This                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | instruction does                                | not have any operation                                  | ands                                     |                                                                                              |  |  |
| Opcode       | LSW: 0000 00<br>MSW: 0111 11                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                 |                                                         |                                          |                                                                                              |  |  |
| Description  | placing MST<br>for debuggin<br>of the pipelin                                                                                                                                                                                                                                                                                                                                     | The MSTOP instruction must be placed to indicate the end of each task. In addition, placing MSTOP in unused memory locations within the CLA program RAM can be usefu for debugging and preventing run away CLA code. When MSTOP enters the D2 phase of the pipeline, the MIRUN flag for the task is cleared and the associated interrupt is flagged in the PIE vector table.                                                                                                                                        |                                                 |                                                         |                                          |                                                                                              |  |  |
|              | There are three special cases that can occur when single-stepping a task such that the MPC reaches the MSTOP instruction.                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                 |                                                         |                                          |                                                                                              |  |  |
|              | <ol> <li>If you are single-stepping or halted in "task A" and "task B" comes in before the MPC<br/>reaches the MSTOP, then "task B" will start if you continue to step through the<br/>MSTOP instruction. Basically if "task B" is pending before the MPC reaches MSTOP<br/>in "task A" then there is no issue in "task B" starting and no special action is required.</li> </ol> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                 |                                                         |                                          |                                                                                              |  |  |
|              | the MST0<br>in the MII<br>the MST0<br>in. To reli                                                                                                                                                                                                                                                                                                                                 | 2. In this case you have single-stepped or halted in "task A" and the MPC has reached<br>the MSTOP with no tasks pending. If "task B" comes in at this point, it will be flagged<br>in the MIFR register but it may or may not start if you continue to single-step through<br>the MSTOP instruction of "task A". It depends on exactly when the new task comes<br>in. To reliably start "task B" perform a soft reset and reconfigure the MIER bits. Once<br>this is done, you can start single-stepping "task B". |                                                 |                                                         |                                          |                                                                                              |  |  |
|              | in (for exa<br>single-ste<br>tasks per                                                                                                                                                                                                                                                                                                                                            | ample usin<br>pped or h<br>iding. Befo                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ng the IACK<br>alted in "tasl<br>ore forcing "t | instruction to sta<br>A" and the MP<br>ask B", run free | art the task). In th<br>C has reached th | when "task B" comes<br>nis case you have<br>ne MSTOP with no<br>out of the debug<br>bugging. |  |  |
| Restrictions | The MSTOP<br>MCCNDD or                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                 |                                                         | tions before or af                       | iter a MBCNDD,                                                                               |  |  |
| Flags        | This instructi                                                                                                                                                                                                                                                                                                                                                                    | on does n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | not modify fla                                  | gs in the MSTF                                          | register.                                |                                                                                              |  |  |
|              | Flag                                                                                                                                                                                                                                                                                                                                                                              | TF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ZF                                              | NF                                                      | LUF                                      | LVF                                                                                          |  |  |
|              | Modified                                                                                                                                                                                                                                                                                                                                                                          | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | No                                              | No                                                      | No                                       | No                                                                                           |  |  |
| Pipeline     |                                                                                                                                                                                                                                                                                                                                                                                   | he MSTC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | P instruction                                   |                                                         |                                          | avior of the MSTOP ions of a MBCNDD,                                                         |  |  |



| Instruction | Set |
|-------------|-----|
|-------------|-----|

| Table 8-33. Pipeline Activity For MSTOP |       |       |       |       |    |    |    |   |
|-----------------------------------------|-------|-------|-------|-------|----|----|----|---|
| Instruction                             | F1    | F2    | D1    | D2    | R1 | R2 | E  | w |
| 11                                      | l1    |       |       |       |    |    |    |   |
| 12                                      | 12    | 11    |       |       |    |    |    |   |
| 13                                      | 13    | 12    | l1    |       |    |    |    |   |
| MSTOP                                   | MSTOP | 13    | 12    | l1    |    |    |    |   |
| 14                                      | 14    | MSTOP | 13    | 12    | l1 |    |    |   |
| 15                                      | 15    | 14    | MSTOP | 13    | 12 | 11 |    |   |
| 16                                      | 16    | 15    | 14    | MSTOP | 13 | 12 | 11 |   |
| New Task Arbitrated and<br>Piroitized   | -     | -     | -     | -     | -  | 13 | 12 |   |
| New Task Arbitrated and<br>Piroitized   | -     | -     | -     | -     | -  | -  | 13 |   |
| 11                                      | 11    | -     | -     | -     | -  | -  | -  |   |
| 12                                      | 12    | l1    | -     | -     | -  | -  | -  |   |
| 13                                      | 13    | 12    | l1    | -     | -  | -  | -  |   |
| 14                                      | 14    | 13    | 12    | l1    | -  | -  | -  |   |
| 15                                      | 15    | 14    | 13    | 12    | 11 | -  | -  |   |
| 16                                      | 16    | 15    | 14    | 13    | 12 | 11 | -  |   |
| 17                                      | 17    | 16    | 15    | 14    | 13 | 12 | l1 |   |
| etc                                     |       |       |       |       |    |    |    |   |

Example

See also

MDEBUGSTOP

# MSUB32 MRa, MRb, MRc 32-Bit Integer Subtraction

| Operands    |                                                         |                                                                                                                                                           |                   |                                                                                                                                     |                       |         |     |  |
|-------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------|-----|--|
|             | MRa                                                     | CLA f                                                                                                                                                     | loating-poin      | t destination register                                                                                                              | r (MR0 to MF          | R3)     |     |  |
|             | MRb                                                     | CLA f                                                                                                                                                     | loating-poin      | t destination register                                                                                                              | r (MR0 to MF          | R3)     |     |  |
|             | MRc                                                     | CLA f                                                                                                                                                     | loating-poin      | t destination register                                                                                                              | r (MR0 to MF          | R3)     |     |  |
| Opcode      | LSW: 0000 000cc bbaa<br>MSW: 0111 1100 1110 0000        |                                                                                                                                                           |                   |                                                                                                                                     |                       |         |     |  |
| Description | -                                                       | ger addition of<br>= MARb(31:0                                                                                                                            |                   |                                                                                                                                     |                       |         |     |  |
| Flags       |                                                         |                                                                                                                                                           |                   | owing flags in the                                                                                                                  | o MSTE ro             | aistor: |     |  |
| 1 1495      | Flag                                                    | TF                                                                                                                                                        | ZF                | NF                                                                                                                                  |                       | LUF     | LVF |  |
|             | Modified                                                | No                                                                                                                                                        | Yes               | Yes                                                                                                                                 |                       | No      | No  |  |
|             | The MSTF                                                | register flag                                                                                                                                             | s are mo          | dified as follows:                                                                                                                  | :                     |         |     |  |
|             | NF = MRa(3                                              | 1);                                                                                                                                                       |                   |                                                                                                                                     |                       |         |     |  |
|             | ZF = 0;<br>if(MRa(31:                                   | 0) == 0) { 2                                                                                                                                              | ZF = 1; }         |                                                                                                                                     |                       |         |     |  |
| Pipeline    | This is a si                                            | ngle-cycle in                                                                                                                                             | struction.        |                                                                                                                                     |                       |         |     |  |
| Example     | ; B<br>; C<br>;<br>;                                    | <pre>= (int32)1<br/>= (int32)2<br/>= (int32)-7<br/>Y2 = A - B<br/><br/>MR0, @_A<br/>MR1, @_B<br/>MR2, @_C<br/>MR3, MR0,<br/>MR3, MR3,<br/>@_Y2, MR3</pre> | MR1<br>MR2        | <pre>; MR0 = 1 (0x00<br/>; MR1 = 2 (0x00<br/>; MR2 = -7 (0xF<br/>; A + B<br/>; A + B + C = 6<br/>; Store y2<br/>; End of task</pre> | 0000002)<br>FFFFFFF9) | 06)     |     |  |
| See also    | MAND32 M<br>MASR32 M<br>MLSL32 M<br>MLSR32 M<br>MOR32 M | MRa, MRb, M<br>MRa, MRb, M<br>MRa, #SHIFT<br>IRa, #SHIFT<br>MRa, #SHIFT<br>Ra, MRb, MF<br>MRa, MRb, M                                                     | /IRc<br>-<br>- Rc |                                                                                                                                     |                       |         |     |  |



# MSUBF32 MRa, MRb, MRc 32-Bit Floating-Point Subtraction

| Operands    |                              |                      |                       |                       |                |     |  |
|-------------|------------------------------|----------------------|-----------------------|-----------------------|----------------|-----|--|
|             | MRa                          | CLA                  | floating-point de     | stination register (M | R0 to R1)      |     |  |
|             | MRb                          | CLA                  | floating-point so     | urce register (MR0 t  | o R1)          |     |  |
|             | MRc                          | CLA                  | floating-point so     | urce register (MR0 t  | to R1)         |     |  |
| Opcode      | LSW: 0000 00<br>MSW: 0111 11 |                      |                       |                       |                |     |  |
| Description | Subtract the<br>MRa = MRb -  |                      | of two floating       | ppoint registers      |                |     |  |
| Flags       | This instruct                | ion modifie          | es the followir       | ng flags in the M     | ISTF register: |     |  |
|             | Flag                         | TF                   | ZF                    | NF                    | LUF            | LVF |  |
|             | Modified                     | No                   | No                    | No                    | Yes            | Yes |  |
|             | The MSTF r                   | eaister flac         | is are modifie        | ed as follows:        |                |     |  |
|             |                              |                      |                       | an underflow co       | ondition.      |     |  |
|             |                              |                      | 0                     | an overflow con       |                |     |  |
| Pipeline    | This is a sing               | gle-cycle ir         | nstruction.           |                       |                |     |  |
| Example     |                              |                      |                       |                       |                |     |  |
| Example     | ; Given A, H                 | 3 and C ar           | e 32-bit flo          | ating-point nur       | nbers          |     |  |
|             | ; Calculate                  | Y2 = A +             | B – C                 |                       |                |     |  |
|             | ,<br>_ClalTask5:             |                      |                       |                       |                |     |  |
|             | MMOV32                       | MR0, @_A             |                       | MR0 with A            |                |     |  |
|             | MMOV32<br>MADDF32            | MR1, @_B<br>MR0 MR1  | ; Load<br>, MR0 ; Add | MR1 with B            |                |     |  |
|             | MADDF 32                     | MR0, MR1<br>MR1, @_C |                       | d in parallel 1       | load C         |     |  |
|             | MSUBF32                      |                      |                       | ract C from (A        | + B)           |     |  |
|             | MMOV32<br>MSTOP              | @Y, MR0              |                       | ) – C<br>of task      |                |     |  |
| <b>A</b>    |                              |                      |                       |                       |                |     |  |
| See also    | MSUBF32 M                    |                      |                       | V32 MRa, mem          | 30             |     |  |
|             |                              |                      |                       | V32 mem32, Mi         |                |     |  |
|             |                              |                      |                       | BF32 MRd, MR          |                |     |  |
|             |                              |                      |                       |                       |                |     |  |



# MSUBF32 MRa, #16FHi, MRb 32-Bit Floating-Point Subtraction

|             | · · ·                                                               |                                                                                                                 |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|-------------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------|--|--|--|
| Operands    | MRa                                                                 | CLA floating-point                                                                                              | destination register (MF                                                                                                                   | R0 to R1)                                                                       |                                                                |  |  |  |
|             | #16FHi                                                              | A 16-bit immediat                                                                                               | e value that represents to<br>bw 16-bits of the mantiss                                                                                    | the upper 16-bits of a                                                          |                                                                |  |  |  |
|             | MRb                                                                 |                                                                                                                 | source register (MR0 to                                                                                                                    |                                                                                 |                                                                |  |  |  |
| Opcode      | LSW: IIII III                                                       | I IIII IIII                                                                                                     |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             | MSW: 0111 100                                                       | 0 0000 baaa                                                                                                     |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
| Description |                                                                     | from the floating-p<br>ne addition in MRa.                                                                      | -                                                                                                                                          | ted by the imme                                                                 | diate operand. Store                                           |  |  |  |
|             | floating-point<br>most useful fo<br>Some exampl<br>(0xBFC00000      | value. The low 16-k<br>or representing cons<br>es are 2.0 (0x4000<br>). The assembler w<br>alue -1.5 can be rep | ue that represents to<br>bits of the mantissa<br>stants where the low<br>0000), 4.0 (0x4080<br>vill accept either a horesented as #-1.5 of | are assumed to<br>west 16-bits of th<br>0000), 0.5 (0x3F<br>lex or float as the | be all 0. #16FHi is<br>ne mantissa are 0.<br>000000), and -1.5 |  |  |  |
| lags        | This instruction modifies the following flags in the MSTF register: |                                                                                                                 |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             | Flag 1                                                              | F ZF                                                                                                            | NF                                                                                                                                         | LUF                                                                             | LVF                                                            |  |  |  |
|             | Modified N                                                          | lo No                                                                                                           | No                                                                                                                                         | Yes                                                                             | Yes                                                            |  |  |  |
| Example     | ; $Y = sqrt(X)$                                                     |                                                                                                                 |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
| Example     | -                                                                   | te(1/sqrt(X));                                                                                                  |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             |                                                                     | 5 - Ye*Ye*X*0.5)                                                                                                |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             |                                                                     | 5 - Ye*Ye*X*0.5)                                                                                                |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             | ; Y = X*Ye<br>;                                                     |                                                                                                                 |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             | _ClalTask3:                                                         |                                                                                                                 |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             | MMOV32                                                              | MRO, @_x                                                                                                        | ; MRO = X                                                                                                                                  |                                                                                 | \ \                                                            |  |  |  |
|             | MEISQRIF32<br>MMOV32                                                | MR1, MR0<br>MR1, @_x, EQ                                                                                        | ; MR1 = Ye = Es<br>; if(X == 0.0)                                                                                                          | -                                                                               | ))                                                             |  |  |  |
|             | MMPYF32                                                             | MR3, MR0, #0.5                                                                                                  | ; MR3 = X*0.5                                                                                                                              |                                                                                 |                                                                |  |  |  |
|             | MMPYF32                                                             | MR2, MR1, MR3                                                                                                   | ; MR2 = Ye*X*0.                                                                                                                            | 5                                                                               |                                                                |  |  |  |
|             | MMPYF32<br>MSUBF32                                                  | MMPYF32 MR2, MR1, MR2 ; MR2 = Ye*Ye*X*0.5<br>MSUBF32 MR2, #1.5, MR2 ; MR2 = 1.5 - Ye*Ye*X*0.5                   |                                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             | MMPYF32                                                             | MR1, MR1, MR2                                                                                                   | ; MR1 = Ye = Ye                                                                                                                            | *(1 5 - Ye*Ye*X                                                                 | *0.5)                                                          |  |  |  |
|             | MMPYF32                                                             | MR2, MR1, MR3                                                                                                   | ; $MR2 = Ye * X * 0$ .                                                                                                                     | 5                                                                               |                                                                |  |  |  |
|             | MMPYF32                                                             |                                                                                                                 | ; MR2 = Ye*Ye*X                                                                                                                            | *0.5                                                                            |                                                                |  |  |  |
|             | MSUBF32<br>MMPYF32                                                  | MR2, #1.5, MR2<br>MR1, MR1, MR2                                                                                 | ; MR2 = 1.5 - Y<br>; MR1 = Ye = Ye                                                                                                         |                                                                                 | *0 5)                                                          |  |  |  |
|             | MMPYF32                                                             | MR1, MR1, MR2<br>MR0, MR1, MR0                                                                                  |                                                                                                                                            |                                                                                 | 0.3/                                                           |  |  |  |
|             | MMOV32                                                              | @_y, MR0                                                                                                        | ; Store Y = sqr                                                                                                                            |                                                                                 |                                                                |  |  |  |
|             | MSTOP                                                               |                                                                                                                 | ; end of task                                                                                                                              |                                                                                 |                                                                |  |  |  |
| See also    | MSUBF32 MF                                                          |                                                                                                                 | 1OV32 MRa, mem3<br>1OV32 mem32, MR                                                                                                         |                                                                                 |                                                                |  |  |  |
|             |                                                                     |                                                                                                                 | SUBF32 MRd, MRe                                                                                                                            |                                                                                 |                                                                |  |  |  |

# MSUBF32 MRd, MRe, MRf ||MMOV32 MRa, mem32 32-Bit Floating-Point Subtraction with Parallel Move

| Operands     |                                                                     |                                                                                                                                                    |                                           |                                                                          |                           |                        |  |  |  |
|--------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------------------------------|---------------------------|------------------------|--|--|--|
| •            | MRd                                                                 |                                                                                                                                                    |                                           | stination register (M<br>ame register as MR                              | R0 to MR3) for the N<br>a | ISUBF32 operation      |  |  |  |
|              | MRe                                                                 | CI                                                                                                                                                 | A floating-point so                       | urce register (MR0 t                                                     | o MR3) for the MSU        | 3F32 operation         |  |  |  |
|              | MRf                                                                 | CI                                                                                                                                                 | A floating-point so                       | urce register (MR0 t                                                     | o MR3) for the MSU        | 3F32 operation         |  |  |  |
|              | MRa                                                                 |                                                                                                                                                    |                                           | stination register (M<br>ame register as MR                              | R0 to MR3) for the M<br>d | IMOV32 operation       |  |  |  |
|              | mem32                                                               |                                                                                                                                                    | 2-bit memory location<br>MOV32 operation. | on accessed using d                                                      | irect or indirect addre   | essing. Source for the |  |  |  |
| Opcode       | LSW: mmmm m<br>MSW: 0010 f                                          |                                                                                                                                                    |                                           |                                                                          |                           |                        |  |  |  |
| Description  | point registe<br>MRd = MRe -                                        | Subtract the contents of two floating-point registers and move from memory to a floating-<br>point register.<br>MRd = MRe - MRf;<br>MRa = [mem32]; |                                           |                                                                          |                           |                        |  |  |  |
| Restrictions |                                                                     |                                                                                                                                                    | ster for the MSI<br>same register a       |                                                                          | MMOV32 must b             | e unique. That is,     |  |  |  |
| Flags        | This instruction modifies the following flags in the MSTF register: |                                                                                                                                                    |                                           |                                                                          |                           |                        |  |  |  |
|              | Flag                                                                | TF                                                                                                                                                 | ZF                                        | NF                                                                       | LUF                       | LVF                    |  |  |  |
|              | Modified                                                            | No                                                                                                                                                 | Yes                                       | Yes                                                                      | Yes                       | Yes                    |  |  |  |
|              | <ul> <li>LUF = 1</li> <li>LVF = 1</li> </ul>                        | if MSUB<br>if MSUB                                                                                                                                 | F32 generates                             | ed as follows:<br>an underflow co<br>an overflow con<br>e NF and ZF flag | dition.                   |                        |  |  |  |
| Pipeline     | Both MSUB                                                           | F32 and                                                                                                                                            | MMOV32 com                                | plete in a single                                                        | cycle.                    |                        |  |  |  |
| Example      | NF = MRa(31<br>ZF = 0;<br>if(MRa(30:2                               |                                                                                                                                                    | { ZF = 1; NF                              | = 0; }                                                                   |                           |                        |  |  |  |
| See also     | MSUBF32 M<br>MSUBF32 M<br>MMPYF32 M                                 | /Ra, #16                                                                                                                                           | SFHi, MRb                                 | BF32 MRd, MR                                                             | e, MRf                    |                        |  |  |  |

# MSUBF32 MRd, MRe, MRf ||MMOV32 mem32, MRa 32-Bit Floating-Point Subtraction with Parallel Move

| Operands    |                                                                                    |                                                                               |                             |                                |                    |                  |  |  |  |  |
|-------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-----------------------------|--------------------------------|--------------------|------------------|--|--|--|--|
| -           | MRd CLA floating-point destination register (MR0 to MR3) for the MSUBF32 operation |                                                                               |                             |                                |                    |                  |  |  |  |  |
|             | MRe                                                                                | C                                                                             | LA floating-point s         | ource register (MR0 t          | o MR3) for the MSU | BF32 operation   |  |  |  |  |
|             | MRf                                                                                | MRf CLA floating-point source register (MR0 to MR3) for the MSUBF32 operation |                             |                                |                    |                  |  |  |  |  |
|             | mem32                                                                              | mem32 32-bit destination memory location for the MMOV32 operation             |                             |                                |                    |                  |  |  |  |  |
|             | MRa                                                                                | C                                                                             | LA floating-point se        | ource register (MR0 t          | o MR3) for the MMC | V32 operation    |  |  |  |  |
| Opcode      |                                                                                    | LSW: mmmm mmmm mmmm<br>MSW: 0110 ffee ddaa addr                               |                             |                                |                    |                  |  |  |  |  |
| Description | Subtract th<br>register to                                                         |                                                                               | s of two floatin            | g-point registers              | and move from      | a floating-point |  |  |  |  |
|             | MRd = MRe<br>[mem32] =                                                             |                                                                               |                             |                                |                    |                  |  |  |  |  |
| Flags       | This instruction modifies the following flags in the MSTF register:                |                                                                               |                             |                                |                    |                  |  |  |  |  |
|             | Flag                                                                               | TF                                                                            | ZF                          | NF                             | LUF                | LVF              |  |  |  |  |
|             | Modified                                                                           | No                                                                            | No                          | No                             | Yes                | Yes              |  |  |  |  |
|             | The MSTF                                                                           | The MSTF register flags are modified as follows:                              |                             |                                |                    |                  |  |  |  |  |
|             | <ul> <li>LUF = 1 if MSUBF32 generates an underflow condition.</li> </ul>           |                                                                               |                             |                                |                    |                  |  |  |  |  |
|             | <ul> <li>LVF = 1 if MSUBF32 generates an overflow condition.</li> </ul>            |                                                                               |                             |                                |                    |                  |  |  |  |  |
| Pipeline    | Both MSU                                                                           | BF32 and                                                                      | MMOV32 con                  | nplete in a single             | cycle.             |                  |  |  |  |  |
| Example     |                                                                                    |                                                                               |                             |                                |                    |                  |  |  |  |  |
| See also    | MSUBF32                                                                            | MRa, #10<br>MRd, MF                                                           | 6FHi, MRb<br>Re, MRf    MMC | )V32 MRa, mem<br>JBF32 MRd, MR |                    |                  |  |  |  |  |

# MSWAPF MRa, MRb {, CNDF} Conditional Swap

# Operands

| Operands   |                                 |                     |                                 |                                                                                                 |                    |            |  |
|------------|---------------------------------|---------------------|---------------------------------|-------------------------------------------------------------------------------------------------|--------------------|------------|--|
|            | MRa                             | CL                  | A floating-po                   | int register (MR0 to MR3)                                                                       |                    |            |  |
|            | MRb                             | CL                  | A floating-po                   | int register (MR0 to MR3)                                                                       |                    |            |  |
|            | CNDF                            | Op                  | tional conditi                  | on tested based on the MSTF                                                                     | flags              |            |  |
| Dpcode     |                                 |                     | 000 CNDF bbaa<br>011 0000 0000  |                                                                                                 |                    |            |  |
| escription | Conditiona                      | al swap of N        | /Ra and I                       | MRb.                                                                                            |                    |            |  |
|            | if (CNDF                        | == true) sv         | vap MRa ar                      | nd MRb;                                                                                         |                    |            |  |
|            | CNDF is c                       | one of the fo       | ollowing c                      | onditions:                                                                                      |                    |            |  |
|            | Encode <sup>(1)</sup>           | CNDF                |                                 | Description                                                                                     | MSTF Fla           | gs Tested  |  |
|            | 0000                            | NEQ                 |                                 | Not equal to zero                                                                               | ZF == 0            |            |  |
|            | 0001                            | EQ                  |                                 | Equal to zero                                                                                   | ZF == 1            |            |  |
|            | 0010                            | GT                  |                                 | Greater than zero                                                                               | ZF == 0 A          | ND NF == 0 |  |
|            | 0011                            | GEQ                 |                                 | Greater than or equal to ze                                                                     | ero NF == 0        |            |  |
|            | 0100                            | LT                  |                                 | Less than zero                                                                                  | NF == 1            |            |  |
|            | 0101                            | LEQ                 |                                 | Less than or equal to zero                                                                      | ZF == 1 C          | 0R NF == 1 |  |
|            | 1010                            | TF                  |                                 | Test flag set                                                                                   | TF == 1            |            |  |
|            | 1011                            | NTF                 |                                 | Test flag not set                                                                               | TF == 0            |            |  |
|            | 1100                            | LU                  |                                 | Latched underflow                                                                               | LUF == 1           |            |  |
|            | 1101                            | LV                  |                                 | Latched overflow                                                                                | LVF == 1           |            |  |
|            | 1110                            | UNC                 |                                 | Unconditional                                                                                   | None               |            |  |
|            | 1111                            | UNCF <sup>(2)</sup> |                                 | Unconditional with flag modification                                                            | None               |            |  |
| lags       | <sup>(2)</sup> This is the modi | fied when a co      | ration if no (<br>onditional op | CNDF field is specified. This co<br>eration is executed. All other c<br>lowing flags in the MST | conditions will no |            |  |
|            | Flag                            | TF                  | ZF                              | NF                                                                                              | LUF                | LVF        |  |
|            | Modified                        | No                  | No                              | No                                                                                              | No                 | No         |  |

Pipeline

This is a single-cycle instruction.



Example

| ; a<br>; t<br>;<br>; N<br>; | nd has len e<br>he array and<br>ote: MCMPF32 | y of 32-bit floati<br>elements. Find the<br>d store it in Resu<br>2 and MSWAPF can k | e n<br>ult  | naximum value in                                                                                                                 |
|-----------------------------|----------------------------------------------|--------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| _CI                         |                                              |                                                                                      | ;<br>;      | Start address<br>Length of the array<br>delay for MAR1 load<br>delay for MAR1 load                                               |
| LOO                         | P<br>MMOV32<br>MCMPF32<br>MSWAPF<br>MADDF32  | MR2, MR1<br>MR1, MR2, GT<br>MR0, MR0, #-1.0                                          | ;;;;;       | <pre>MR1 = X0 MR2 = next element Compare MR2 with MR1 MR1 = MAX(MR1, MR2) Decrement the counter Set/clear flags for MBCNDD</pre> |
|                             |                                              | @_Result, MR1                                                                        | ;<br>;<br>; | Branch if not equal to zero<br>Always executed<br>Always executed<br>Always executed<br>End of task                              |

See also



# MMTESTTF CNDF Test MSTF Register Flag Condition

#### Operands

| Opcode | LSW: | 0000 | 0000 | 0000 | cndf |
|--------|------|------|------|------|------|
|        | MSW: | 0111 | 1111 | 0100 | 0000 |

CNDF

Description

Test the CLA floating-point condition and if true, set the MSTF[TF] flag. If the condition is false, clear the MSTF[TF] flag. This is useful for temporarily storing a condition for later use.

condition to test based on MSTF flags

if (CNDF == true) TF = 1; else TF = 0;

#### CNDF is one of the following conditions:

| Encode <sup>(3)</sup> | CNDF                | Description                          | MSTF Flags Tested   |
|-----------------------|---------------------|--------------------------------------|---------------------|
| 0000                  | NEQ                 | Not equal to zero                    | ZF == 0             |
| 0001                  | EQ                  | Equal to zero                        | ZF == 1             |
| 0010                  | GT                  | Greater than zero                    | ZF == 0 AND NF == 0 |
| 0011                  | GEQ                 | Greater than or equal to zero        | NF == 0             |
| 0100                  | LT                  | Less than zero                       | NF == 1             |
| 0101                  | LEQ                 | Less than or equal to zero           | ZF == 1 OR NF == 1  |
| 1010                  | TF                  | Test flag set                        | TF == 1             |
| 1011                  | NTF                 | Test flag not set                    | TF == 0             |
| 1100                  | LU                  | Latched underflow                    | LUF == 1            |
| 1101                  | LV                  | Latched overflow                     | LVF == 1            |
| 1110                  | UNC                 | Unconditional                        | None                |
| 1111                  | UNCF <sup>(4)</sup> | Unconditional with flag modification | None                |

<sup>(3)</sup> Values not shown are reserved.

(4) This is the default operation if no CNDF field is specified. This condition will allow the ZF and NF flags to be modified when a conditional operation is executed. All other conditions will not modify these flags.

#### Flags

#### This instruction modifies the following flags in the MSTF register:

| Flag TF      | 26 | NF | LUF | LVF |  |
|--------------|----|----|-----|-----|--|
| Modified Yes | No | No | No  | No  |  |

TF = 0; if (CNDF == true) TF = 1;

Note: If (CNDF == UNC or UNCF), the TF flag will be set to 1.

Pipeline

This is a single-cycle instruction.





| www.ti.com |  |
|------------|--|

| Example | <pre>; if (State == 0.1) ; RampState = RampState    RAMPMASK ; else if (State == 0.01) ; CoastState = CoastState    COASTMASK ; else ; SteadyState = SteadyState    STEADYMASK ; ClalTask2:</pre>                                                                                                                                                                                     |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | MMOV32 MR0, @_State<br>MCMPF32 MR0, #0.1 ; Affects flags for 1st MBCNDD (A)<br>MCMPF32 MR0, #0.01 ; Check used by 2nd MBCNDD (B)<br>MMTESTTF EQ ; Store EQ flag in TF for 2nd MBCNDD (B)<br>MNOP                                                                                                                                                                                      |
|         | MBCNDD _Skip1, NEQ ; (A) If State != 0.1, go to Skip1<br>MMOV32 MR1, @_RampState ; Always executed<br>MMOVXI MR2, #RAMPMASK ; Always executed<br>MOR32 MR1, MR2 ; Always executed<br>MMOV32 @_RampState, MR1 ; Execute if (A) branch not taken<br>MSTOP ; end of task if (A) branch not taken                                                                                         |
|         | _Skip1:<br>MMOV32 MR3, @_SteadyState<br>MMOVXI MR2, #STEADYMASK<br>MOR32 MR3, MR2<br>MBCNDD _Skip2, NTF ; (B) if State != .01, go to Skip2<br>MMOV32 MR1, @_CoastState ; Always executed<br>MMOVXI MR2, #COASTMASK ; Always executed<br>MOR32 MR1, MR2 ; Always executed<br>MMOV32 @_CoastState, MR1 ; Execute if (B) branch not taken<br>MSTOP ; end of task if (B) branch not taken |
|         | _Skip2:<br>MMOV32 @_SteadyState, MR3 ; Executed if (B) branch taken<br>MSTOP                                                                                                                                                                                                                                                                                                          |

See also

# MUI16TOF32 MRa, mem16 Convert Unsigned 16-Bit Integer to 32-Bit Floating-Point Value

| • • • • • • • • • • • • • • • • • • • • |                                                                                |                                                         |                                   |                        |                |                                      |     |
|-----------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------|------------------------|----------------|--------------------------------------|-----|
|                                         | MRa                                                                            | CL                                                      | A floating-point de               | estination register (M | IR0 to MR3)    |                                      |     |
|                                         | mem16                                                                          | 16                                                      | -bit source memor                 | y location             |                |                                      |     |
| Opcode                                  | LSW: mmmm                                                                      | mmmm mmmm                                               | mmmm                              |                        |                |                                      |     |
|                                         | MSW: 0111                                                                      | 0101 01aa                                               | addr                              |                        |                |                                      |     |
| Description                             |                                                                                |                                                         |                                   |                        | MF32TOI16/UI16 | operation trunca<br>st (even) value. | tes |
|                                         | MRa = UI16                                                                     | TOF32[mem                                               | 16];                              |                        |                |                                      |     |
| Flags                                   | This instru                                                                    | ction does                                              | not affect any                    | flags:                 |                |                                      |     |
|                                         | Flag                                                                           | TF                                                      | ZF                                | NF                     | LUF            | LVF                                  |     |
|                                         | Modified                                                                       | No                                                      | No                                | No                     | No             | No                                   |     |
| Pipeline                                | This is a si                                                                   | ingle-cycle                                             | instruction.                      |                        |                |                                      |     |
| Example                                 |                                                                                |                                                         |                                   |                        |                |                                      |     |
| See also                                | MF32TOI1<br>MF32TOI1<br>MF32TOU<br>MF32TOU<br>MI16TOF3<br>MI16TOF3<br>MUI16TOF | 6R MRa,<br>I16 MRa,<br>I16R MRa<br>2 MRa, M<br>2 MRa, m | MRb<br>MRb<br>, MRb<br>Rb<br>em16 |                        |                |                                      |     |
|                                         |                                                                                |                                                         |                                   |                        |                |                                      |     |



#### MUI16TOF32 MRa, MRb Convert Unsigned 16-Bit Integer to 32-Bit Floating-Point Value

| oporanao            |                                                     |                                                                                        |                                      |                                                    |             |                                               |
|---------------------|-----------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------|-------------|-----------------------------------------------|
|                     | MRa                                                 | Cl                                                                                     | A floating-point de                  | estination register (M                             | IR0 to MR3) |                                               |
|                     | MRb                                                 | CL                                                                                     | A floating-point so                  | ource register (MR0 t                              | to MR3)     |                                               |
| Opcode              | LSW: 0000                                           | 0000 0000                                                                              | bbaa                                 |                                                    |             |                                               |
|                     | MSW: 0111                                           | . 1110 1110                                                                            | 0000                                 |                                                    |             |                                               |
| Description         | float32 to<br>the MF32                              | 116/UI16 d                                                                             | ata format, the<br>16R operation     | MF32TOI16/UI                                       |             | When converting<br>acates to zero while<br>e. |
| Flags               |                                                     | uction does                                                                            | s not affect any<br>ZF               | flags:                                             | LUF         | LVF                                           |
|                     | Flag<br>Modified                                    | No                                                                                     | No                                   | No                                                 | No          | No                                            |
| Pipeline<br>Example | MMOVXI MR                                           | 1, #0x800F                                                                             |                                      | = 32783 (0x800F<br>FOF32 (MR1(15:0<br>(0x47000F00) |             |                                               |
| See also            | MF32TOI<br>MF32TOU<br>MF32TOU<br>MI16TOF<br>MI16TOF | 16 MRa, M<br>16R MRa,<br>JI16 MRa,<br>JI16R MRa<br>32 MRa, M<br>32 MRa, m<br>9532 MRa, | MRb<br>MRb<br>a, MRb<br>IRb<br>iem16 |                                                    |             |                                               |

# MUI32TOF32 MRa, mem32 Convert Unsigned 32-Bit Integer to 32-Bit Floating-Point Value

| MRa                                                                                                                                      | CL                                                                                                                                                                                                                                                                                                                                                                                         | A floating-po                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | int destination regis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ter (MR0 to M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mem32                                                                                                                                    | 32-                                                                                                                                                                                                                                                                                                                                                                                        | bit memory I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ocation accessed us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | sing direct or i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ndirect addre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ssing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LSW: mmmm                                                                                                                                | mmmm mmmm                                                                                                                                                                                                                                                                                                                                                                                  | mmmm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| MRa = UI32                                                                                                                               | 2TOF32[mem3                                                                                                                                                                                                                                                                                                                                                                                | 32];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| This instru                                                                                                                              | ction does                                                                                                                                                                                                                                                                                                                                                                                 | not affect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | any flags:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Flag                                                                                                                                     | TF                                                                                                                                                                                                                                                                                                                                                                                         | ZF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | NF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | LUF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | LVF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Modified                                                                                                                                 | No                                                                                                                                                                                                                                                                                                                                                                                         | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| This is a s                                                                                                                              | ingle-cycle                                                                                                                                                                                                                                                                                                                                                                                | instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ٦.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ;<br>; x2 = Uin<br>; m2 = Uin<br>; b2 = Uin<br>;<br>; Calculat<br>;<br>_ClalTask:<br>MUI32TC<br>MUI32TC<br>MUI32TC<br>MMPYF32<br>MADDF32 | nt32(2) = (<br>nt32(1) = (<br>nt32(3) = (<br>te y2 = x2<br>l:<br>DF32 MR0,<br>DF32 MR1,<br>DF32 MR2,<br>2 MR3,<br>JI32 MR3,                                                                                                                                                                                                                                                                | 0x00000002<br>0x00000003<br>* m2 + b2<br>@_m2<br>@_x2<br>@_b2<br>MR0, MR1<br>MR2, MR3<br>MR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ; MR0 = 1.0 (<br>; MR1 = 2.0 (<br>; MR2 = 3.0 (<br>; M*X<br>; Y=MX+B = 5.<br>; Y = Uint32(                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000000)<br>0x40400000)<br>0 (0x40A000<br>5.0) = 0x00<br>t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | )))))))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| MF32TOU<br>MI32TOF3<br>MI32TOF3                                                                                                          | 1132 MRa, 1<br>32 MRa, m<br>32 MRa, MI                                                                                                                                                                                                                                                                                                                                                     | MRb<br>em32<br>Rb                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                          | mem32           LSW: mmmm           MSW: 0111           MRa = UI33           This instru           Flag           Modified           This is a s           ; Given x3           ; x2 = Uin           ; b2 = Uin           ; Calculat           ;           ; Calculat           ;           MUI32TO           MMOV32           MSTOP           MF32TOL           MI32TOF           MI32TOF | mem32         32-           LSW: mmmm mmmm mmmm         MSW: 0111 0100 10aa           MRa = UI32TOF32[mem3           This instruction does           Flag         TF           Modified         No           This is a single-cycle           ; Given x2, m2 and k           ; x2 = Uint32(2) = 0           ; m2 = Uint32(1) = 0           ; b2 = Uint32(3) = 0           ;           ; Calculate y2 = x2           ;           _ClalTask1:           MUI32TOF32           MMYF32           MR32TOUI32           MR32TOUI32           MF32TOUI32           MR32TOF32           MR32TOF32           MR32TOF32           MR32TOF32           MR32TOF32           MR32TOF32 | mem32         32-bit memory I           LSW: mmmm mmmm mmmm mmmm         MSW: 0111 0100 10aa addr           MRa = UI32TOF32[mem32];           This instruction does not affect           Flag         TF           ZF           Modified         No           No           This is a single-cycle instruction           ; Given x2, m2 and b2 are Uir;           ; x2 = Uint32(2) = 0x0000002           ; m2 = Uint32(1) = 0x0000001           ; b2 = Uint32(3) = 0x0000003           ;           .Claltask1:           MUI32TOF32           MU32TOF32           MR1, @_x2           MU32TOF32           MR3, MR0, MR1           MADDF32           MR3, MR0, MR1           MADDF32           MR3, MR3, MR3           MMOV32         @_y2, MR3 | mem32         32-bit memory location accessed u           LSW: mmmm mmmm mmmm         MSW: 0111 0100 10aa addr           MRa = UI32TOF32[mem32];           This instruction does not affect any flags:           Flag         TF           ZF         NF           Modified         No           No         No           This is a single-cycle instruction.           ; Given x2, m2 and b2 are Uint32 numbers:           ;         x2 = Uint32(2) = 0x00000002           ; m2 = Uint32(1) = 0x00000001           ; b2 = Uint32(3) = 0x00000003           ;           ; Calculate y2 = x2 * m2 + b2           ; | 32-bit memory location accessed using direct or i           LSW: mmmm mmmm mmmm           MSW: 0111 0100 10aa addr           MRa = UI32TOF32[mem32];           This instruction does not affect any flags:           Flag         TF           ZF         NF           Modified         No           No         No           This is a single-cycle instruction.           ; Given x2, m2 and b2 are Uint32 numbers:           ; x2 = Uint32(1) = 0x00000002           ; m2 = Uint32(1) = 0x00000001           ; b2 = Uint32(3) = 0x00000003           ; Calculate y2 = x2 * m2 + b2           ;          ClaITask1:           MUI32TOF32           MUI32TOF32           MR0, @m2         ; MR0 = 1.0 (0x3F800000)           MUI32TOF32         MR0, @m2           ; MR1 = 2.0 (0x4000000)           MUI32TOF32         MR2, @m2           ; MR2 = 3.0 (0x40400000)           MMPYF32         MR3, MR0, MR1           MADDF32         MR3, MR0, MR1           MF32TOUI32         MR3, MR3           MF32TOUI32         MR3, MR5           MF32TOUI32         MR3, MRb           MF32TOUI32         MR3, MRb           MF32TOUI32         MR | 32-bit memory location accessed using direct or indirect addre           LSW: mmmm mmmm mmmm mmmm           MSW: 0111 0100 10aa addr           MRa = UI32TOF32[mem32];           This instruction does not affect any flags:           Flag         TF         ZF         NF         LUF           Modified         No         No         No         No           This is a single-cycle instruction.           ; Given x2, m2 and b2 are Uint32 numbers:         ;         ;         ; 2 = Uint32(2) = 0x00000002         ; m2 = Uint32(1) = 0x00000003         ;           ; Calculate y2 = x2 * m2 + b2         ; | 32-bit memory location accessed using direct or indirect addressing           LSW: mmmm mmmm mmmm mmmm mmmm           MSW: 0111 0100 10aa addr           MRa = UI32TOF32[mem32];           This instruction does not affect any flags:           Flag         TF         ZF         NF         LUF         LVF           Modified         No         No         No         No         No           This instruction does not affect any flags:           This instruction does not affect any flags:           Given x2, m2 and b2 are Uint32 numbers:           ;         x2 = Uint32(2) = 0x00000002         ;         m2 = Uint32(1) = 0x00000001         ;         b2 = Uint32(3) = 0x00000003         ;           ;         claltask1:         MUI32TOF32         MR0, em2 ; MR0 = 1.0 (0x3F800000)         MUI32TOF32         MR3, MR2, MR1 ; M*X           MADDF32         MR3, MR0, MR1 ; M*X         MADDF32         MR3, MR2, MR3 ; Y = Uint32(5.0) = 0x00000005           MU32TOF32         MR3, MR3, MR3 ; Y = Uint32(5.0) = 0x00000005         MOV32         @_y2, MR3 ; store result           MSTOP         ; end of task         MF32TOUI32 MRa, MRb         MS2TOF32 MRa, MRb           MIS2TOF32 MRa, MRb         MIS2TOF32 MRa, MRb         MIS2TOF32 MRa, MRb |

#### MUI32TOF32 MRa, MRb Convert Unsigned 32-Bit Integer to 32-Bit Floating-Point Value

| • • • • • • • • • • • • • • • • • • • • |                                 |                                                                |                           |                        |                |              |  |
|-----------------------------------------|---------------------------------|----------------------------------------------------------------|---------------------------|------------------------|----------------|--------------|--|
|                                         | MRa                             | CLA                                                            | floating-point de         | estination register (M | R0 to MR3)     |              |  |
|                                         | MRb                             | CLA                                                            | floating-point sc         | ource register (MR0 t  | o MR3)         |              |  |
| Opcode                                  |                                 | 0000 0000 B<br>1101 1100 (                                     |                           |                        |                |              |  |
| Description                             |                                 | TOF32 [MRb]                                                    |                           |                        |                |              |  |
| Flags                                   | This instruc                    | ction does r                                                   | not affect any            | flags:                 |                |              |  |
|                                         | Flag                            | TF                                                             | ZF                        | NF                     | LUF            | LVF          |  |
|                                         | Modified                        | No                                                             | No                        | No                     | No             | No           |  |
| Pipeline                                | This is a si                    | ngle-cycle i                                                   | nstruction.               |                        |                |              |  |
| Example                                 | MMOVIZ<br>MMOVXI<br>MUI32TOF32  | MR3, #0x11                                                     | L11 ; MR3(15<br>; MR3 = 2 | 2147488017             | = 2147488017.0 | (0x4F000011) |  |
| See also                                | MF32TOU<br>MI32TOF3<br>MI32TOF3 | 2 MRa, MR<br>I32 MRa, M<br>2 MRa, me<br>2 MRa, MR<br>32 MRa, m | Rb<br>m32<br>b            |                        |                |              |  |
|                                         |                                 |                                                                |                           |                        |                |              |  |



#### MXOR32 MRa, MRb, MRc Bitwise Exclusive Or

#### Operands

| Operands            |                                                                     |                                                          |                     |                       |            |     |  |  |  |  |  |
|---------------------|---------------------------------------------------------------------|----------------------------------------------------------|---------------------|-----------------------|------------|-----|--|--|--|--|--|
|                     | MRa                                                                 | CL/                                                      | A floating-point de | stination register (M | R0 to MR3) |     |  |  |  |  |  |
|                     | MRb                                                                 | CL/                                                      | A floating-point so | urce register (MR0 t  | o MR3)     |     |  |  |  |  |  |
|                     | MRc                                                                 | CL/                                                      | A floating-point so | urce register (MR0 t  | o MR3)     |     |  |  |  |  |  |
| Opcode              | LSW: 0000 00<br>MSW: 0111 1                                         |                                                          |                     |                       |            |     |  |  |  |  |  |
| Description         | Bitwise XOR                                                         | R of MRb                                                 | with MRc.           |                       |            |     |  |  |  |  |  |
|                     | MARa(31:0) :                                                        | = MARb(31                                                | :0) XOR MRc(3       | 1:0);                 |            |     |  |  |  |  |  |
| Flags               | This instruction modifies the following flags in the MSTF register: |                                                          |                     |                       |            |     |  |  |  |  |  |
|                     | Flag                                                                | TF                                                       | ZF                  | NF                    | LUF        | LVF |  |  |  |  |  |
|                     | Modified                                                            | No                                                       | Yes                 | Yes                   | No         | No  |  |  |  |  |  |
| Pipeline<br>Example | This is a sin<br>MMOVIZ MR0,<br>MMOVXI MR                           | #0x5555                                                  | ; MR0 = 0x5         | 555AAAA               |            |     |  |  |  |  |  |
|                     | MMOVIZ MR.<br>MMOVIZ MR.                                            | 1, #0x543                                                | 2 ; MR1 = 0         | x5432FEDC             |            |     |  |  |  |  |  |
|                     | ; 0101 X01<br>; 0101 X01<br>; 0101 X01                              | R 0100 =                                                 | 0001 (1)            |                       |            |     |  |  |  |  |  |
|                     | ; 0101 XO                                                           |                                                          |                     |                       |            |     |  |  |  |  |  |
|                     |                                                                     | ; 1010 XOR 1111 = 0101 (5)<br>; 1010 XOR 1110 = 0100 (4) |                     |                       |            |     |  |  |  |  |  |
|                     | ; 1010 XOI<br>; 1010 XOI                                            |                                                          |                     |                       |            |     |  |  |  |  |  |
|                     | ; 1010 X01                                                          |                                                          |                     |                       |            |     |  |  |  |  |  |
|                     | MXOR32 MR                                                           | 2, MR1, M                                                | IRO ; MR3 = 0       | x01675476             |            |     |  |  |  |  |  |
| See also            | MAND32 MI<br>MOR32 MR                                               |                                                          |                     |                       |            |     |  |  |  |  |  |

MOR32 MRa, MRb, MRc



#### 8.7 Appendix A: CLA and CPU Arbitration

Typically, CLA activity is independent of the CPU activity. Under the circumstance where both the CLA and the CPU are attempting to access memory or a peripheral register within the same interface concurrently, an arbitration procedure will occur. This appendix describes this arbitration.

# 8.7.1 CLA and CPU Arbitration

Typically, CLA activity is independent of the CPU activity. Under the circumstance where both the CLA and the CPU are attempting to access memory or a peripheral register within the same interface concurrently, an arbitration procedure will occur. The one exception is the ADC result registers which do not create a conflict when read by both the CPU and the CLA simultaneously even if different addresses are accessed. Any combined accesses between the different interfaces, or where the CPU access is outside of the interface that the CLA is accessing do not create a conflict.

The interfaces that can have conflict arbitration are:

- CLA Message RAMs
- CLA Program Memory
- CLA Data RAMs

#### 8.7.1.1 CLA Message RAMs

Message RAMs consist of two blocks. These blocks are for passing data between the main CPU and the CLA. No opcode fetches are allowed from the message RAMs. The two message RAMs have the following characteristics:

#### CLA to CPU Message RAM:

The following accesses are allowed:

- CPU reads
- CLA reads and writes
- CPU debug reads and writes

The following accesses are ignored

CPU writes

Priority of accesses are (highest priority first):

- 1. CLA write
- 2. CPU debug write
- 3. CPU data read, program read, CPU debug read
- CLA data read

#### CPU to CLA Message RAM:

The following accesses are allowed:

- CPU reads and writes
- CLA reads
- CPU debug reads and writes

The following accesses are ignored

- CLA writes

Priority of accesses are (highest priority first):

- 1. CLA read
- 2. CPU data write, program write, CPU debug write
- 3. CPU data read, CPU debug read
- 4. CPU program read



#### Appendix A: CLA and CPU Arbitration

#### 8.7.1.2 CLA Program Memory

The behavior of the program memory depends on the state of the MMEMCFG[PROGE] bit. This bit controls whether the memory is mapped to CLA space or CPU space.

#### • MMEMCFG[PROGE] == 0

In this case the memory is mapped to the CPU. The CLA will be halted and no tasks shoud be incoming.

- Any CLA fetch will be treated as an illegal opcode condition as described in Section 8.3.4. This
  condition will not occur if the proper procedure is followed to map the program memory.
- CLA reads and writes cannot occur
- The memory block behaves as any normal SARAM block mapped to CPU memory space.

Priroty of accesses are (highest priority first):

- 1. CPU data write, program write, debug write
- 2. CPU data read, program read, debug read
- 3. CPU fetch, program read

#### MMEMCFG[PROGE] == 1

In this case the memory block is mapped to CLA space. The CPU can only make debug accesses.

- CLA reads and writes cannot occur
- CLA fetches are allowed
- CPU fetches return 0 which is an illegal opcode and will cause an ITRAP interrupt.
- CPU data reads and program reads return 0
- CPU data writes and program writes are ignored
- Priroty of accesses are (highest priority first):
- 1. CLA fetch
- 2. CPU debug write
- 3. CPU debug read
- **NOTE:** Because the CLA fetch has higher priority than CPU debug reads, it is possible for the CLA to permanently block debug accesses if the CLA is executing in a loop. This might occur when initially developing CLA code due to a bug. To avoid this issue, the program memory will return all 0x0000 for CPU debug reads (ignore writes) when the CLA is running. When the CLA is halted or idle then normal CPU debug read and write access can be performed.



#### 8.7.1.3 CLA Data Memory

There are three independent data memory blocks. The behavior of the data memory depends on the state of the MMEMCFG[RAM0E], MMEMCFG[RAM1E] and MMEMCFG[RAM2E] bits. These bits determine whether the memory blocks are mapped to CLA space or CPU space.

# • MMEMCFG[RAMxE] == 0, MMEMCFG[RAMxCPUE] = 0/1

In this case the memory block is mapped to the CPU.

- CLA fetches cannot occur to this block.
- CLA reads return 0.
- CLA writes are ignored.
- The memory block behaves as any normal SARAM block mapped to the CPU memory space.

Priroty of accesses are (highest priority first):

- 1. CPU data write/program write/debug access write
- 2. CPU data read/debug access read
- 3. CPU fetch/program read

# • MMEMCFG[RAMxE] == 1, MMEMCFG[RAMxCPUE] = 0

In this case the memory block is mapped to CLA space. The CPU can make only debug accesses.

- CLA fetches cannot occur to this block.
- CLA read and CLA writes are allowed.
- CPU fetches return 0
- CPU data reads and program reads return 0.
- CPU data writes and program writes are ignored.

Priority of accesses are (highest priority first):

- 1. CLA data write
- 2. CPU debug write
- 3. CPU debug read
- 4. CLA read

# • MMEMCFG[RAMxE] == 1, MMEMCFG[RAMxCPUE] = 1

In this case the memory block is mapped to CLA space. The CPU has read and write access to the memory in addition to debug accesses.

- CLA fetches cannot occur to this block.
- CLA read and CLA writes are allowed.
- CPU fetches return 0
- CPU data reads and writes are allowed.
- CPU program reads return 0 while program writes are ignored.

Priority of accesses are (highest priority first):

- 1. CLA data write
- 2. CPU debug access write/CPU data write
- 3. CPU debug access read/ CPU data read
- 4. CLA read

#### 8.7.1.4 Peripheral Registers (ePWM, Comparator and PGA (Analog subsystem), eCAP, eQEP)

Accesses to the registers follow these rules:

- If both the CPU and CLA request access at the same time, then the CLA will have priority and the main CPU is stalled.
- If a CPU access is in progress and another CPU access is pending, then the CLA will have priority over the pending CPU access. In this case the CLA access will begin when the current CPU access completes.



- While a CPU access is in progress any incoming CLA access will be stalled.
- While a CLA access is in progress any incoming CPU access will be stalled.
- A CPU write operation has priority over a CPU read operation.
- A CLA write operation has priority over a CLA read operation.
- If the CPU is performing a read-modify-write operation and the CLA performs a write to the same location, the CLA write may be lost if the operation occurs in-between the CPU read and write. For this reason, you should not mix CPU and CLA accesses to same location.



Page

# Inter-Integrated Circuit (I2C) Module

This guide describes the features and operation of the inter-integrated circuit (I2C) module that is available on the TMS320x2805x family of controllers. The I2C module provides an interface between one of these devices and devices compliant with Philips Semiconductors Inter-IC bus (I2C-bus) specification version 2.1 and connected by way of an I2C-bus. External components attached to this 2-wire serial bus can transmit/receive 1 to 8-bit data to/from the device through the I2C module. This guide assumes the reader is familiar with the I2C-bus specification.

**NOTE:** A unit of data transmitted or received by the I2C module can have fewer than 8 bits; however, for convenience, a unit of data is called a data byte throughout this document. (The number of bits in a data byte is selectable via the BC bits of the mode register, I2CMDR.)

#### Topic

# 9.1Introduction to the I2C Module6609.2I2C Module Operational Details6639.3Interrupt Requests Generated by the I2C Module6699.4Resetting/Disabling the I2C Module6709.5I2C Module Registers670



#### 9.1 Introduction to the I2C Module

The I2C module supports any slave or master I2C-compatible device. Figure 9-1 shows an example of multiple I2C modules connected for a two-way transfer from one device to other devices.





#### 9.1.1 Features

The I2C module has the following features:

- Compliance with the Philips Semiconductors I2C-bus specification (version 2.1):
  - Support for 8-bit format transfers
  - 7-bit and 10-bit addressing modes
  - General call
  - START byte mode
  - Support for multiple master-transmitters and slave-receivers
  - Support for multiple slave-transmitters and master-receivers
  - Combined master transmit/receive and receive/transmit mode
- Data transfer rate of from 10 kbps up to 400 kbps (Philips Fast-mode rate)
- One 4-level receive FIFO and one 4-level transmit FIFO
- One interrupt that can always be used by the CPU. This interrupt can be generated as a result of one
  of the following conditions: transmit-data ready, receive-data ready, register-access ready, noacknowledgment received, arbitration lost, stop condition detected, addressed as slave.
- An additional interrupt that can be used by the CPU when in FIFO mode
- Module enable/disable capability
- Free data format mode

# 9.1.2 Features Not Supported

The I2C module does not support:

- High-speed mode (Hs-mode)
- CBUS-compatibility mode

# 9.1.3 Functional Overview

Each device connected to an I2C-bus is recognized by a unique address. Each device can operate as either a transmitter or a receiver, depending on the function of the device. A device connected to the I2C-bus can also be considered as the master or the slave when performing data transfers. A master device is the device that initiates a data transfer on the bus and generates the clock signals to permit that transfer. During this transfer, any device addressed by this master is considered a slave. The I2C module supports the multi-master mode, in which one or more devices capable of controlling an I2C-bus can be connected to the same I2C-bus.

For data communication, the I2C module has a serial data pin (SDA) and a serial clock pin (SCL), as shown in Figure 9-2. These two pins carry information between the F2805x device and other devices connected to the I2C-bus. The SDA and SCL pins both are bidirectional. They each must be connected to a positive supply voltage using a pull-up resistor. When the bus is free, both pins are high. The driver of these two pins has an open-drain configuration to perform the required wired-AND function.

There are two major transfer techniques:

- Standard Mode: Send exactly n data values, where n is a value you program in an I2C module register. See Table 9-5 for register information.
- Repeat Mode: Keep sending data values until you use software to initiate a STOP condition or a new START condition. See Table 9-5 for RM bit information.

•

The I2C module consists of the following primary blocks:

- A serial interface: one data pin (SDA) and one clock pin (SCL)
- Data registers and FIFOs to temporarily hold receive data and transmit data traveling between the SDA pin and the CPU
- Control and status registers
- A peripheral bus interface to enable the CPU to access the I2C module registers and FIFOs.



#### Introduction to the I2C Module

- A clock synchronizer to synchronize the I2C input clock (from the device clock generator) and the clock on the SCL pin, and to synchronize data transfers with masters of different clock speeds
- A prescaler to divide down the input clock that is driven to the I2C module
- · A noise filter on each of the two pins, SDA and SCL
- An arbitrator to handle arbitration between the I2C module (when it is a master) and another master
- Interrupt generation logic, so that an interrupt can be sent to the CPU
- FIFO interrupt generation logic, so that FIFO access can be synchronized to data reception and data transmission in the I2C module

Figure 9-2 shows the four registers used for transmission and reception in non-FIFO mode. The CPU writes data for transmission to I2CDXR and reads received data from I2CDRR. When the I2C module is configured as a transmitter, data written to I2CDXR is copied to I2CXSR and shifted out on the SDA pin one bit a time. When the I2C module is configured as a receiver, received data is shifted into I2CRSR and then copied to I2CDRR.



Figure 9-2. I2C Module Conceptual Block Diagram

#### 9.1.4 Clock Generation

As shown in Figure 9-3, the device clock generator receives a signal from an external clock source and produces an I2C input clock with a programmed frequency. The I2C input clock is equivalent to the CPU clock and is then divided twice more inside the I2C module to produce the module clock and the master clock.



Figure 9-3. Clocking Diagram for the I2C Module

The module clock determines the frequency at which the I2C module operates. A programmable prescaler in the I2C module divides down the I2C input clock to produce the module clock. To specify the divide-down value, initialize the IPSC field of the prescaler register, I2CPSC. The resulting frequency is:

module clock frequency = 
$$\frac{I2C \text{ input clock frequency}}{(IPSC + 1)}$$

**NOTE:** To meet all of the I2C protocol timing specifications, the module clock must be configured between 7 - 12 MHz.

The prescaler must be initialized only while the I2C module is in the reset state (IRS = 0 in I2CMDR). The prescaled frequency takes effect only when IRS is changed to 1. Changing the IPSC value while IRS = 1 has no effect.

The master clock appears on the SCL pin when the I2C module is configured to be a master on the I2Cbus. This clock controls the timing of communication between the I2C module and a slave. As shown in Figure 9-3, a second clock divider in the I2C module divides down the module clock to produce the master clock. The clock divider uses the ICCL value of I2CCLKL to divide down the low portion of the module clock signal and uses the ICCH value of I2CCLKH to divide down the high portion of the module clock signal. See section Section 9.5.7.1 for the master clock frequency equation.

# 9.2 I2C Module Operational Details

This section provides an overview of the I2C-bus protocol and how it is implemented.

#### 9.2.1 Input and Output Voltage Levels

One clock pulse is generated by the master device for each data bit transferred. Due to a variety of different technology devices that can be connected to the I2C-bus, the levels of logic 0 (low) and logic 1 (high) are not fixed and depend on the associated level of  $V_{DD}$ . For details, see the data manual for your particular device.

#### 9.2.2 Data Validity

The data on SDA must be stable during the high period of the clock (see Figure 9-4). The high or low state of the data line, SDA, should change only when the clock signal on SCL is low.



#### Figure 9-4. Bit Transfer on the I2C-Bus



#### 9.2.3 Operating Modes

The I2C module has four basic operating modes to support data transfers as a master and as a slave. See Table 9-1 for the names and descriptions of the modes.

If the I2C module is a master, it begins as a master-transmitter and typically transmits an address for a particular slave. When giving data to the slave, the I2C module must remain a master-transmitter. To receive data from a slave, the I2C module must be changed to the master-receiver mode.

If the I2C module is a slave, it begins as a slave-receiver and typically sends acknowledgment when it recognizes its slave address from a master. If the master will be sending data to the I2C module, the module must remain a slave-receiver. If the master has requested data from the I2C module, the module must be changed to the slave-transmitter mode.

| Operating Mode           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Slave-receiver modes     | The I2C module is a slave and receives data from a master.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                          | All slaves begin in this mode. In this mode, serial data bits received on SDA are shifted in with the clock pulses that are generated by the master. As a slave, the I2C module does not generate the clock signal, but it can hold SCL low while the intervention of the device is required (RSFULL = 1 in I2CSTR) after a byte has been received. See section Section 9.2.7 for more details.                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| Slave-transmitter mode   | The I2C module is a slave and transmits data to a master.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|                          | This mode can be entered only from the slave-receiver mode; the I2C module must first receive a command from the master. When you are using any of the 7-bit/10-bit addressing formats, the I2C module enters its slave-transmitter mode if the slave address byte is the same as its own address (in I2COAR) and the master has transmitted $R/W = 1$ . As a slave-transmitter, the I2C module then shifts the serial data out on SDA with the clock pulses that are generated by the master. While a slave, the I2C module does not generate the clock signal, but it can hold SCL low while the intervention of the device is required (XSMT = 0 in I2CSTR) after a byte has been transmitted. See section Section 9.2.7 for more details. |  |  |  |  |  |
| Master-receiver mode     | The I2C module is a master and receives data from a slave.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| Master-receiver mode     | This mode can be entered only from the master-transmitter mode; the I2C module must first transmit a command to the slave. When you are using any of the 7-bit/10-bit addressing formats, the I2C module enters its master-receiver mode after transmitting the slave address byte and $R/W = 1$ . Serial data bits on SDA are shifted into the I2C module with the clock pulses generated by the I2C module on SCL. The clock pulses are inhibited and SCL is held low when the intervention of the device is required (RSFULL = 1 in I2CSTR) after a byte has been received.                                                                                                                                                                |  |  |  |  |  |
| Master-transmitter modes | The IC module is a master and transmits control information and data to a slave.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|                          | All masters begin in this mode. In this mode, data assembled in any of the 7-bit/10-bit addressing formats is shifted out on SDA. The bit shifting is synchronized with the clock pulses generated by the I2C module on SCL. The clock pulses are inhibited and SCL is held low when the intervention of the device is required (XSMT = 0 in I2CSTR) after a byte has been transmitted.                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |

#### Table 9-1. Operating Modes of the I2C Module



#### 9.2.4 I2C Module START and STOP Conditions

START and STOP conditions can be generated by the I2C module when the module is configured to be a master on the I2C-bus. As shown in Figure 9-5:

- The START condition is defined as a high-to-low transition on the SDA line while SCL is high. A master drives this condition to indicate the start of a data transfer.
- The STOP condition is defined as a low-to-high transition on the SDA line while SCL is high. A master drives this condition to indicate the end of a data transfer.

#### Figure 9-5. I2C Module START and STOP Conditions



After a START condition and before a subsequent STOP condition, the I2C-bus is considered busy, and the bus busy (BB) bit of I2CSTR is 1. Between a STOP condition and the next START condition, the bus is considered free, and BB is 0.

For the I2C module to start a data transfer with a START condition, the master mode bit (MST) and the START condition bit (STT) in I2CMDR must both be 1. For the I2C module to end a data transfer with a STOP condition, the STOP condition bit (STP) must be set to 1. When the BB bit is set to 1 and the STT bit is set to 1, a repeated START condition is generated. For a description of I2CMDR and its bits (including MST, STT, and STP), see Section 9.5.1.

#### 9.2.5 Serial Data Formats

Figure 9-6 shows an example of a data transfer on the I2C-bus. The I2C module supports 1 to 8-bit data values. In Figure 9-6, 8-bit data is transferred. Each bit put on the SDA line equates to 1 pulse on the SCL line, and the values are always transferred with the most significant bit (MSB) first. The number of data values that can be transmitted or received is unrestricted. The serial data format used in Figure 9-6 is the 7-bit addressing format. The I2C module supports the formats shown in Figure 9-7 through Figure 9-9 and described in the paragraphs that follow the figures.

**NOTE:** In Figure 9-6 through Figure 9-9, n = the number of data bits (from 1 to 8) specified by the bit count (BC) field of I2CMDR.

#### Figure 9-6. I2C Module Data Transfer (7-Bit Addressing with 8-bit Data Configuration Shown)



I2C Module Operational Details

| Figure 9-7. I2C Module 7-Bit Addressing Format (FDF = 0, XA = 0 in I2CMDR |
|---------------------------------------------------------------------------|
|---------------------------------------------------------------------------|

| 1 | ₹ 7             | 1   | 1   | • n• | 1   | • n• | 1   | 1 |
|---|-----------------|-----|-----|------|-----|------|-----|---|
| S | x x x x x x x x | R/W | ACK | Data | ACK | Data | ACK | Ρ |
|   | 1               |     |     |      |     |      |     |   |

7 bits of slave address

#### Figure 9-8. I2C Module 10-Bit Addressing Format (FDF = 0, XA = 1 in I2CMDR)

| 1 🛉 🗕 | 7             | → 1 | 1   | 8                       | 1   | • n• | 1   | 1 |
|-------|---------------|-----|-----|-------------------------|-----|------|-----|---|
| S     | 1 1 1 1 0 x x | R/W | ACK | x x x x x x x x x       | ACK | Data | ACK | Ρ |
|       | x x = 2 MSBs  |     |     | 8 LSBs of slave address |     |      |     |   |

#### Figure 9-9. I2C Module Free Data Format (FDF = 1 in I2CMDR)

| 1 | ← n ─► | 1   | • n• | 1   | ▲ n ► | 1   | 1 |
|---|--------|-----|------|-----|-------|-----|---|
| S | Data   | ACK | Data | ACK | Data  | ACK | Ρ |

#### 9.2.5.1 7-Bit Addressing Format

In the 7-bit addressing format (see Figure 9-7), the first byte after a START condition (S) consists of a 7-bit slave address followed by a R/W bit. R/W determines the direction of the data:

- $R/\overline{W} = 0$ : The master writes (transmits) data to the addressed slave.
- $R/\overline{W} = 1$ : The master reads (receives) data from the slave.

An extra clock cycle dedicated for acknowledgment (ACK) is inserted after each byte. If the ACK bit is inserted by the slave after the first byte from the master, it is followed by n bits of data from the transmitter (master or slave, depending on the R/W bit). n is a number from 1 to 8 determined by the bit count (BC) field of I2CMDR. After the data bits have been transferred, the receiver inserts an ACK bit.

To select the 7-bit addressing format, write 0 to the expanded address enable (XA) bit of I2CMDR, and make sure the free data format mode is off (FDF = 0 in I2CMDR).

#### 9.2.5.2 10-Bit Addressing Format

The 10-bit addressing format (see Figure 9-8) is similar to the 7-bit addressing format, but the master sends the slave address in two separate byte transfers. The first byte consists of 11110b, the two MSBs of the 10-bit slave address, and R/W = 0 (write). The second byte is the remaining 8 bits of the 10-bit slave address. The slave must send acknowledgment after each of the two byte transfers. Once the master has written the second byte to the slave, the master can either write data or use a repeated START condition to change the data direction. For more details about using 10-bit addressing, see the Philips Semiconductors I2C-bus specification.

To select the 10-bit addressing format, write 1 to the XA bit of I2CMDR and make sure the free data format mode is off (FDF = 0 in I2CMDR).

#### 9.2.5.3 Free Data Format

In this format (see Figure 9-9), the first byte after a START condition (S) is a data byte. An ACK bit is inserted after each data byte, which can be from 1 to 8 bits, depending on the BC field of I2CMDR. No address or data-direction bit is sent. Therefore, the transmitter and the receiver must both support the free data format, and the direction of the data must be constant throughout the transfer.

To select the free data format, write 1 to the free data format (FDF) bit of I2CMDR. The free data format is not supported in the digital loopback mode (DLB = 1 in I2CMDR).

#### 9.2.5.4 Using a Repeated START Condition

At the end of each data byte, the master can drive another START condition. Using this capability, a master can communicate with multiple slave addresses without having to give up control of the bus by driving a STOP condition. The length of a data byte can be from 1 to 8 bits and is selected with the BC field of I2CMDR. The repeated START condition can be used with the 7-bit addressing, 10-bit addressing, and free data formats. Figure 9-10 shows a repeated START condition in the 7-bit addressing format.

Figure 9-10. Repeated START Condition (in This Case, 7-Bit Addressing Format)



**NOTE:** In Figure 9-10, n = the number of data bits (from 1 to 8) specified by the bit count (BC) field of I2CMDR.

# 9.2.6 NACK Bit Generation

When the I2C module is a receiver (master or slave), it can acknowledge or ignore bits sent by the transmitter. To ignore any new bits, the I2C module must send a no-acknowledge (NACK) bit during the acknowledge cycle on the bus. Table 9-2 summarizes the various ways you can tell the I2C module to send a NACK bit.

| I2C Module Condition                                             | NACK Bit Generation Options                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Slave-receiver modes                                             | <ul> <li>Allow an overrun condition (RSFULL = 1 in I2CSTR)</li> <li>Reset the module (IRS = 0 in I2CMDR)</li> <li>Set the NACKMOD bit of I2CMDR before the rising edge of the last data bit you intend to receive</li> </ul>                                                                                                                                                         |
| Master-receiver mode AND<br>Repeat mode (RM = 1 in I2CMDR)       | <ul> <li>Generate a STOP condition (STP = 1 in I2CMDR)</li> <li>Reset the module (IRS = 0 in I2CMDR)</li> <li>Set the NACKMOD bit of I2CMDR before the rising edge of the last data bit you intend to receive</li> </ul>                                                                                                                                                             |
| Master-receiver mode AND<br>Nonrepeat mode<br>(RM = 0 in I2CMDR) | <ul> <li>If STP = 1 in I2CMDR, allow the internal data counter to count down to 0 and thus force a STOP condition</li> <li>If STP = 0, make STP = 1 to generate a STOP condition</li> <li>Reset the module (IRS = 0 in I2CMDR). = 1 to generate a STOP condition</li> <li>Set the NACKMOD bit of I2CMDR before the rising edge of the last data bit you intend to receive</li> </ul> |

#### Table 9-2. Ways to Generate a NACK Bit

#### 9.2.7 Clock Synchronization

Under normal conditions, only one master device generates the clock signal, SCL. During the arbitration procedure, however, there are two or more masters and the clock must be synchronized so that the data output can be compared. Figure 9-11 illustrates the clock synchronization. The wired-AND property of SCL means that a device that first generates a low period on SCL overrules the other devices. At this high-to-low transition, the clock generators of the other devices are forced to start their own low period. The SCL is held low by the device with the longest low period. The other devices that finish their low periods must wait for SCL to be released, before starting their high periods. A synchronized signal on SCL is 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, the result is that all clock generators must enter the wait state. In this way, a slave slows down a fast master and the slow device creates enough time to store a received byte or to prepare a byte to be transmitted.



# Figure 9-11. Synchronization of Two I2C Clock Generators During Arbitration

#### 9.2.8 Arbitration

If two or more master-transmitters attempt to start a transmission on the same bus at approximately the same time, an arbitration procedure is invoked. The arbitration procedure uses the data presented on the serial data bus (SDA) by the competing transmitters. Figure 9-12 illustrates the arbitration procedure between two devices. The first master-transmitter, which release the SDA line high, is overruled by another master-transmitter that drives SDA low. The arbitration procedure gives priority to the device that transmits the serial data stream with the lowest binary value. Should two or more devices send identical first bytes, arbitration continues on the subsequent bytes.

If the I2C module is the losing master, it switches to the slave-receiver mode, sets the arbitration lost (AL) flag, and generates the arbitration-lost interrupt request.

If during a serial transfer the arbitration procedure is still in progress when a repeated START condition or a STOP condition is transmitted to SDA, the master-transmitters involved must send the repeated START condition or the STOP condition at the same position in the format frame. Arbitration is not allowed between:

- A repeated START condition and a data bit
- A STOP condition and a data bit
- A repeated START condition and a STOP condition

#### Figure 9-12. Arbitration Procedure Between Two Master-Transmitters





#### 9.3 Interrupt Requests Generated by the I2C Module

The I2C module can generate seven types of basic interrupt requests, which are described in Section 9.3.1. Two of these can tell the CPU when to write transmit data and when to read receive data. If you want the FIFOs to handle transmit and receive data, you can also use the FIFO interrupts described in Section 9.3.2. The basic I2C interrupts are combined to form PIE Group 8, Interrupt 1 (I2CINT1A\_ISR), and the FIFO interrupts are combined to form PIE Group 8, Interrupt 2 (I2CINT2A\_ISR).

# 9.3.1 Basic I2C Interrupt Requests

The I2C module generates the interrupt requests described in Table 9-3. As shown in Figure 9-13, all requests are multiplexed through an arbiter to a single I2C interrupt request to the CPU. Each interrupt request has a flag bit in the status register (I2CSTR) and an enable bit in the interrupt enable register (I2CIER). When one of the specified events occurs, its flag bit is set. If the corresponding enable bit is 0, the interrupt request is blocked. If the enable bit is 1, the request is forwarded to the CPU as an I2C interrupt.

The I2C interrupt is one of the maskable interrupts of the CPU. As with any maskable interrupt request, if it is properly enabled in the CPU, the CPU executes the corresponding interrupt service routine (I2CINT1A\_ISR). The I2CINT1A\_ISR for the I2C interrupt can determine the interrupt source by reading the interrupt source register, I2CISRC. Then the I2CINT1A\_ISR can branch to the appropriate subroutine.

After the CPU reads I2CISRC, the following events occur:

- 1. The flag for the source interrupt is cleared in I2CSTR. Exception: The ARDY, RRDY, and XRDY bits in I2CSTR are not cleared when I2CISRC is read. To clear one of these bits, write a 1 to it.
- 2. The arbiter determines which of the remaining interrupt requests has the highest priority, writes the code for that interrupt to I2CISRC, and forwards the interrupt request to the CPU.

| I2C Interrupt Request | Interrupt Source                                                                                                                                                                         |  |  |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| XRDYINT               | Transmit ready condition: The data transmit register (I2CDXR) is ready to accept new data because the previous data has been copied from I2CDXR to the transmit shift register (I2CXSR). |  |  |
|                       | As an alternative to using XRDYINT, the CPU can poll the XRDY bit of the status register, I2CSTR. XRDYINT should not be used when in FIFO mode. Use the FIFO interrupts instead.         |  |  |
| RRDYINT               | Receive ready condition: The data receive register (I2CDRR) is ready to be read because data has been copied from the receive shift register (I2CRSR) to I2CDRR.                         |  |  |
|                       | As an alternative to using RRDYINT, the CPU can poll the RRDY bit of I2CSTR. RRDYINT should not be used when in FIFO mode. Use the FIFO interrupts instead.                              |  |  |
| ARDYINT               | Register-access ready condition: The I2C module registers are ready to be accessed because the previously programmed address, data, and command values have been used.                   |  |  |
|                       | The specific events that generate ARDYINT are the same events that set the ARDY bit of I2CSTR.                                                                                           |  |  |
|                       | As an alternative to using ARDYINT, the CPU can poll the ARDY bit.                                                                                                                       |  |  |
| NACKINT               | No-acknowledgment condition: The I2C module is configured as a master-transmitter and did not received acknowledgment from the slave-receiver.                                           |  |  |
|                       | As an alternative to using NACKINT, the CPU can poll the NACK bit of I2CSTR.                                                                                                             |  |  |
| ALINT                 | Arbitration-lost condition: The I2C module has lost an arbitration contest with another master-transmitter                                                                               |  |  |
|                       | As an alternative to using ALINT, the CPU can poll the AL bit of I2CSTR.                                                                                                                 |  |  |
| SCDINT                | Stop condition detected: A STOP condition was detected on the I2C bus.                                                                                                                   |  |  |
|                       | As an alternative to using SCDINT, the CPU can poll the SCD bit of the status register, I2CSTR.                                                                                          |  |  |
| AASINT                | Addressed as slave condition: The I2C has been addressed as a slave device by another master on the I2C bus.                                                                             |  |  |
|                       | As an alternative to using AASINT, the CPU can poll the AAS bit of the status register, I2CSTR.                                                                                          |  |  |

#### Table 9-3. Descriptions of the Basic I2C Interrupt Requests





#### Figure 9-13. Enable Paths of the I2C Interrupt Requests

### 9.3.2 I2C FIFO Interrupts

In addition to the seven basic I2C interrupts, the transmit and receive FIFOs each contain the ability to generate an interrupt (I2CINT2A). The transmit FIFO can be configured to generate an interrupt after transmitting a defined number of bytes, up to 4. The receive FIFO can be configured to generate an interrupt after receiving a defined number of bytes, up to 4. These two interrupt sources are ORed together into a single maskable CPU interrupt. The interrupt service routine can then read the FIFO interrupt status flags to determine from which source the interrupt came. See the I2C transmit FIFO register (I2CFFTX) and the I2C receive FIFO register (I2CFFRX) descriptions.

#### 9.4 Resetting/Disabling the I2C Module

You can reset/disable the I2C module in two ways:

- Write 0 to the I2C reset bit (IRS) in the I2C mode register (I2CMDR). All status bits (in I2CSTR) are forced to their default values, and the I2C module remains disabled until IRS is changed to 1. The SDA and SCL pins are in the high-impedance state.
- Initiate a device reset by driving the XRS pin low. The entire device is reset and is held in the reset state until you drive the pin high. When XRS is released, all I2C module registers are reset to their default values. The IRS bit is forced to 0, which resets the I2C module. The I2C module stays in the reset state until you write 1 to IRS.

IRS must be 0 while you configure/reconfigure the I2C module. Forcing IRS to 0 can be used to save power and to clear error conditions.

# 9.5 I2C Module Registers

Table 9-4 lists the I2C module registers. All but the receive and transmit shift registers (I2CRSR and I2CXSR) are accessible to the CPU.

| Name   | Address | Description                   |  |  |  |
|--------|---------|-------------------------------|--|--|--|
| I2COAR | 0x7900  | I2C own address register      |  |  |  |
| I2CIER | 0x7901  | I2C interrupt enable register |  |  |  |

#### Table 9-4. I2C Module Registers

670 Inter-Integrated Circuit (I2C) Module

#### TEXAS INSTRUMENTS

www.ti.com

| Name    | Address | Description                                             |
|---------|---------|---------------------------------------------------------|
| I2CSTR  | 0x7902  | I2C status register                                     |
| I2CCLKL | 0x7903  | I2C clock low-time divider register                     |
| I2CCLKH | 0x7904  | I2C clock high-time divider register                    |
| I2CCNT  | 0x7905  | I2C data count register                                 |
| I2CDRR  | 0x7906  | I2C data receive register                               |
| I2CSAR  | 0x7907  | I2C slave address register                              |
| I2CDXR  | 0x7908  | I2C data transmit register                              |
| I2CMDR  | 0x7909  | I2C mode register                                       |
| I2CISRC | 0x790A  | I2C interrupt source register                           |
| I2CEMDR | 0x790B  | I2C extended mode register                              |
| I2CPSC  | 0x790C  | I2C prescaler register                                  |
| I2CFFTX | 0x7920  | I2C FIFO transmit register                              |
| I2CFFRX | 0x7921  | I2C FIFO receive register                               |
| I2CRSR  | -       | I2C receive shift register (not accessible to the CPU)  |
| I2CXSR  | -       | I2C transmit shift register (not accessible to the CPU) |

#### Table 9-4. I2C Module Registers (continued)

**NOTE:** To use the I2C module, the system clock to the module must be enabled by setting the appropriate bit in the PCLKR0 register. See the *System Control and Interrupts* chapter.



# 9.5.1 I2C Mode Register (I2CMDR)

The I2C mode register (I2CMDR) is a 16-bit register that contains the control bits of the I2C module. The bit fields of I2CMDR are shown in Figure 9-14 and described in Table 9-5.

|         |       | гіу   | ule 9-14. 12C IV | ioue registe |       |       |       |
|---------|-------|-------|------------------|--------------|-------|-------|-------|
| 15      | 14    | 13    | 12               | 11           | 10    | 9     | 8     |
| NACKMOD | FREE  | STT   | Reserved         | STP          | MST   | TRX   | XA    |
| R/W-0   | R/W-0 | R/W-0 | R/W-0            | R/W-0        | R/W-0 | R/W-0 | R/W-0 |
| 7       | 6     | 5     | 4                | 3            | 2     |       | 0     |
| RM      | DLB   | IRS   | STB              | FDF          |       | BC    |       |
| R/W-0   | R/W-0 | R/W-0 | R/W-0            | R/W-0        |       | R/W-0 |       |

#### Figure 9-14. I2C Mode Register (I2CMDR)

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 9-5. I2C Mode Register (I2CMDR) Field Descriptions

| Bit | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | NACKMOD  |       | NACK mode bit. This bit is only applicable when the I2C module is acting as a receiver.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |          | 0     | In the slave-receiver mode: The I2C module sends an acknowledge (ACK) bit to the transmitter during each acknowledge cycle on the bus. The I2C module only sends a no-acknowledge (NACK) bit if you set the NACKMOD bit.                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |          |       | In the master-receiver mode: The I2C module sends an ACK bit during each acknowledge cycle until the internal data counter counts down to 0. At that point, the I2C module sends a NACK bit to the transmitter. To have a NACK bit sent earlier, you must set the NACKMOD bit.                                                                                                                                                                                                                                                                                                                                                                   |
|     |          | 1     | In either slave-receiver or master-receiver mode: The I2C module sends a NACK bit to the transmitter during the next acknowledge cycle on the bus. Once the NACK bit has been sent, NACKMOD is cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |          |       | Important: To send a NACK bit in the next acknowledge cycle, you must set NACKMOD before the rising edge of the last data bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 14  | FREE     |       | This bit controls the action taken by the I2C module when a debugger breakpoint is encountered.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |          | 0     | When I2C module is master:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |          |       | If SCL is low when the breakpoint occurs, the I2C module stops immediately and keeps driving SCL low, whether the I2C module is the transmitter or the receiver. If SCL is high, the I2C module waits until SCL becomes low and then stops.                                                                                                                                                                                                                                                                                                                                                                                                      |
|     |          |       | When I2C module is slave:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |          |       | A breakpoint forces the I2C module to stop when the current transmission/reception is complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |          | 1     | The I2C module runs free; that is, it continues to operate when a breakpoint occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13  | STT      |       | START condition bit (only applicable when the I2C module is a master). The RM, STT, and STP bits determine when the I2C module starts and stops data transmissions (see Table 9-6). Note that the STT and STP bits can be used to terminate the repeat mode, and that this bit is not writable when IRS = 0.                                                                                                                                                                                                                                                                                                                                     |
|     |          | 0     | In the master mode, STT is automatically cleared after the START condition has been generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |          | 1     | In the master mode, setting STT to 1 causes the I2C module to generate a START condition on the I2C-bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 12  | Reserved |       | This reserved bit location is always read as a 0. A value written to this bit has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11  | STP      |       | STOP condition bit (only applicable when the I2C module is a master). In the master mode, the RM, STT, and STP bits determine when the I2C module starts and stops data transmissions (see Table 9-6). Note that the STT and STP bits can be used to terminate the repeat mode, and that this bit is not writable when IRS=0. When in non-repeat mode, at least one byte must be transferred before a stop condition can be generated. The I2C module delays clearing of this bit until after the I2CSTR[SCD] bit is set. To avoid disrupting the I2C state machine, the user must wait until this bit is clear before initiating a new message. |
|     |          | 0     | STP is automatically cleared after the STOP condition has been generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |          | 1     | STP has been set by the device to generate a STOP condition when the internal data counter of the I2C module counts down to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

TEXAS INSTRUMENTS

www.ti.com

| Table 9-5. I2C Mode Register | (I2CMDR) Field De | scriptions (continued) |
|------------------------------|-------------------|------------------------|
|                              |                   |                        |

| Bit | Field | Value | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | MST   |       | Master mode bit. MST determines whether the I2C module is in the slave mode or the master mode. MST is automatically changed from 1 to 0 when the I2C master generates a STOP condition.                                                                                                                                                                                                            |
|     |       | 0     | Slave mode. The I2C module is a slave and receives the serial clock from the master.                                                                                                                                                                                                                                                                                                                |
|     |       | 1     | Master mode. The I2C module is a master and generates the serial clock on the SCL pin.                                                                                                                                                                                                                                                                                                              |
| 9   | TRX   |       | Transmitter mode bit. When relevant, TRX selects whether the I2C module is in the transmitter mode or the receiver mode. Table 9-7 summarizes when TRX is used and when it is a don't care.                                                                                                                                                                                                         |
|     |       | 0     | Receiver mode. The I2C module is a receiver and receives data on the SDA pin.                                                                                                                                                                                                                                                                                                                       |
|     |       | 1     | Transmitter mode. The I2C module is a transmitter and transmits data on the SDA pin.                                                                                                                                                                                                                                                                                                                |
| 8   | XA    |       | Expanded address enable bit.                                                                                                                                                                                                                                                                                                                                                                        |
|     |       | 0     | 7-bit addressing mode (normal address mode). The I2C module transmits 7-bit slave addresses (from bits 6-0 of I2COAR), and its own slave address has 7 bits (bits 6-0 of I2COAR).                                                                                                                                                                                                                   |
|     |       | 1     | 10-bit addressing mode (expanded address mode). The I2C module transmits 10-bit slave addresses (from bits 9-0 of I2COAR), and its own slave address has 10 bits (bits 9-0 of I2COAR).                                                                                                                                                                                                              |
| 7   | RM    |       | Repeat mode bit (only applicable when the I2C module is a master-transmitter). The RM, STT, and STP bits determine when the I2C module starts and stops data transmissions (see Table 9-6).                                                                                                                                                                                                         |
|     |       | 0     | Nonrepeat mode. The value in the data count register (I2CCNT) determines how many bytes are received/transmitted by the I2C module.                                                                                                                                                                                                                                                                 |
|     |       | 1     | Repeat mode. A data byte is transmitted each time the I2CDXR register is written to (or until the transmit FIFO is empty when in FIFO mode) until the STP bit is manually set. The value of I2CCNT is ignored. The ARDY bit/interrupt can be used to determine when the I2CDXR (or FIFO) is ready for more data, or when the data has all been sent and the CPU is allowed to write to the STP bit. |
| 6   | DLB   |       | Digital loopback mode bit. The effects of this bit are shown in Figure 9-15.                                                                                                                                                                                                                                                                                                                        |
|     |       | 0     | Digital loopback mode is disabled.                                                                                                                                                                                                                                                                                                                                                                  |
|     |       | 1     | Digital loopback mode is enabled. For proper operation in this mode, the MST bit must be 1.                                                                                                                                                                                                                                                                                                         |
|     |       |       | In the digital loopback mode, data transmitted out of I2CDXR is received in I2CDRR after n device cycles by an internal path, where:                                                                                                                                                                                                                                                                |
|     |       |       | n = ((I2C input clock frequency/module clock frequency) $\times$ 8)                                                                                                                                                                                                                                                                                                                                 |
|     |       |       | The transmit clock is also the receive clock. The address transmitted on the SDA pin is the address in I2COAR.                                                                                                                                                                                                                                                                                      |
|     |       |       | Note: The free data format (FDF = 1) is not supported in the digital loopback mode.                                                                                                                                                                                                                                                                                                                 |
| 5   | IRS   |       | I2C module reset bit.                                                                                                                                                                                                                                                                                                                                                                               |
|     |       | 0     | The I2C module is in reset/disabled. When this bit is cleared to 0, all status bits (in I2CSTR) are set to their default values.                                                                                                                                                                                                                                                                    |
|     |       | 1     | The I2C module is enabled. This has the effect of releasing the I2C bus if the I2C peripheral is holding it.                                                                                                                                                                                                                                                                                        |
| 4   | STB   |       | START byte mode bit. This bit is only applicable when the I2C module is a master. As described in version 2.1 of the Philips Semiconductors I2C-bus specification, the START byte can be used to help a slave that needs extra time to detect a START condition. When the I2C module is a slave, it ignores a START byte from a master, regardless of the value of the STB bit.                     |
|     |       | 0     | The I2C module is not in the START byte mode.                                                                                                                                                                                                                                                                                                                                                       |
|     |       | 1     | The I2C module is in the START byte mode. When you set the START condition bit (STT), the I2C module begins the transfer with more than just a START condition. Specifically, it generates:                                                                                                                                                                                                         |
|     |       |       | <ol> <li>A START condition</li> <li>A START byte (0000 0001b)</li> </ol>                                                                                                                                                                                                                                                                                                                            |
|     |       |       | <ol> <li>A dummy acknowledge clock pulse</li> <li>A repeated START condition</li> </ol>                                                                                                                                                                                                                                                                                                             |
|     |       |       | Then, as normal, the I2C module sends the slave address that is in I2CSAR.                                                                                                                                                                                                                                                                                                                          |
| 3   | FDF   |       | Free data format mode bit.                                                                                                                                                                                                                                                                                                                                                                          |
|     |       | 0     | Free data format mode is disabled. Transfers use the 7-/10-bit addressing format selected by the XA bit.                                                                                                                                                                                                                                                                                            |
|     |       | 1     | Free data format mode is enabled. Transfers have the free data (no address) format described in Section 9.2.5.                                                                                                                                                                                                                                                                                      |
|     |       |       | The free data format is not supported in the digital loopback mode (DLB=1).                                                                                                                                                                                                                                                                                                                         |



|--|

| Bit | Field | Value | Description                                                                                                                                                                                                                                                                                                                      |  |
|-----|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 2-0 | BC    |       | Bit count bits. BC defines the number of bits (1 to 8) in the next data byte that is to be received transmitted by the I2C module. The number of bits selected with BC must match the data size the other device. Notice that when BC = 000b, a data byte has 8 bits. BC does not affect addres bytes, which always have 8 bits. |  |
|     |       |       | Note: If the bit count is less than 8, receive data is right-justified in I2CDRR(7-0), and the other bits of I2CDRR(7-0) are undefined. Also, transmit data written to I2CDXR must be right-justified.                                                                                                                           |  |
|     |       | 000   | 8 bits per data byte                                                                                                                                                                                                                                                                                                             |  |
|     |       | 001   | 1 bit per data byte                                                                                                                                                                                                                                                                                                              |  |
|     |       | 010   | 2 bits per data byte                                                                                                                                                                                                                                                                                                             |  |
|     |       | 011   | 3 bits per data byte                                                                                                                                                                                                                                                                                                             |  |
|     |       | 100   | 4 bits per data byte                                                                                                                                                                                                                                                                                                             |  |
|     |       | 101   | 5 bits per data byte                                                                                                                                                                                                                                                                                                             |  |
|     |       | 110   | 6 bits per data byte                                                                                                                                                                                                                                                                                                             |  |
|     |       | 111   | 7 bits per data byte                                                                                                                                                                                                                                                                                                             |  |

#### Table 9-5. I2C Mode Register (I2CMDR) Field Descriptions (continued)

# Table 9-6. Master-Transmitter/Receiver Bus Activity Defined by the RM, STT, and STP Bits of I2CMDR

| RM | STT | STP | Bus Activity <sup>(1)</sup> | Description                                                                                                                  |
|----|-----|-----|-----------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0  | 0   | 0   | None                        | No activity                                                                                                                  |
| 0  | 0   | 1   | Р                           | STOP condition                                                                                                               |
| 0  | 1   | 0   | S-A-D(n)D.                  | START condition, slave address, n data bytes (n = value in I2CCNT)                                                           |
| 0  | 1   | 1   | S-A-D(n)D-P                 | START condition, slave address, n data bytes, STOP condition (n = value in I2CCNT)                                           |
| 1  | 0   | 0   | None                        | No activity                                                                                                                  |
| 1  | 0   | 1   | Р                           | STOP condition                                                                                                               |
| 1  | 1   | 0   | S-A-D-D-D.                  | Repeat mode transfer: START condition, slave address, continuous data transfers until STOP condition or next START condition |
| 1  | 1   | 1   | None                        | Reserved bit combination (No activity)                                                                                       |

<sup>(1)</sup> S = START condition; A = Address; D = Data byte; P = STOP condition;

#### Table 9-7. How the MST and FDF Bits of I2CMDR Affect the Role of the TRX Bit of I2CMDR

| MST | FDF | I2C Module State                                | Function of TRX                                                                                                                                                    |
|-----|-----|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | 0   | In slave mode but not free data format mode     | TRX is a don't care. Depending on the command from the master, the I2C module responds as a receiver or a transmitter.                                             |
| 0   | 1   | In slave mode and free data format mode         | The free data format mode requires that the I2C module remains the transmitter or the receiver throughout the transfer. TRX identifies the role of the I2C module: |
|     |     |                                                 | TRX = 1: The I2C module is a transmitter.<br>TRX = 0: The I2C module is a receiver.                                                                                |
| 1   | 0   | In master mode but not free data<br>format mode | TRX = 1: The I2C module is a transmitter.<br>TRX = 0: The I2C module is a receiver.                                                                                |
| 1   | 1   | In master mode and free data format mode        | TRX = 0: The I2C module is a receiver.<br>TRX = 1: The I2C module is a transmitter.                                                                                |





### Figure 9-15. Pin Diagram Showing the Effects of the Digital Loopback Mode (DLB) Bit

# 9.5.2 I2C Extended Mode Register (I2CEMDR)

The I2C extended mode register is shown in Figure 9-16 and described in Table 9-8.

# Figure 9-16. I2C Extended Mode Register (I2CEMDR)

| 15 1     | 0     |
|----------|-------|
| Reserved | BCM   |
| R-0      | R/W-1 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Table 9-8. I2C Extended Mode Register | (I2CEMDR) Field Descriptions |
|---------------------------------------|------------------------------|
|---------------------------------------|------------------------------|

| Bit  | Field    | Value | Description                                                                                                                                                                               |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-1 | Reserved |       | Any writes to these bit(s) must always have a value of 0.                                                                                                                                 |
| 0    | BCM      |       | Backwards compatibility mode. This bit affects the timing of the transmit status bits (XRDY and XSMT) in the I2CSTR register when in slave transmitter mode. See Figure 9-17 for details. |





Figure 9-17. BCM Bit, Slave Transmitter Mode

#### 9.5.3 I2C Interrupt Enable Register (I2CIER)

I2CIER is used by the CPU to individually enable or disable I2C interrupt requests. The bits of I2CIER are shown and described in Figure 9-18 and Table 9-9, respectively.

#### Figure 9-18. I2C Interrupt Enable Register (I2CIER)

| 15       |       |       |       |       |       |       | 8     |  |  |  |
|----------|-------|-------|-------|-------|-------|-------|-------|--|--|--|
|          |       |       | Res   | erved |       |       |       |  |  |  |
| R-0      |       |       |       |       |       |       |       |  |  |  |
| 7        | 6     | 5     | 4     | 3     | 2     | 1     | 0     |  |  |  |
| Reserved | AAS   | SCD   | XRDY  | RRDY  | ARDY  | NACK  | AL    |  |  |  |
| R-0      | R/W-0 |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 9-9. I2C Interrupt Enable Register (I2CIER) Field Descriptions

| Bit  | Field    | Value | Description                                                                                         |
|------|----------|-------|-----------------------------------------------------------------------------------------------------|
| 15-7 | Reserved |       | These reserved bit locations are always read as zeros. A value written to this field has no effect. |
| 6    | AAS      |       | Addressed as slave interrupt enable bit                                                             |
|      |          | 0     | Interrupt request disabled                                                                          |
|      |          | 1     | Interrupt request enabled                                                                           |
| 5    | SCD      |       | Stop condition detected interrupt enable bit                                                        |
|      |          | 0     | Interrupt request disabled                                                                          |
|      |          | 1     | Interrupt request enabled                                                                           |
| 4    | XRDY     |       | Transmit-data-ready interrupt enable bit. This bit should not be set when using FIFO mode.          |
|      |          | 0     | Interrupt request disabled                                                                          |
|      |          | 1     | Interrupt request enabled                                                                           |
| 3    | RRDY     |       | Receive-data-ready interrupt enable bit. This bit should not be set when using FIFO mode.           |
|      |          | 0     | Interrupt request disabled                                                                          |
|      |          | 1     | Interrupt request enabled                                                                           |
| 2    | ARDY     |       | Register-access-ready interrupt enable bit                                                          |
|      |          | 0     | Interrupt request disabled                                                                          |
|      |          | 1     | Interrupt request enabled                                                                           |
| 1    | NACK     |       | No-acknowledgment interrupt enable bit                                                              |
|      |          | 0     | Interrupt request disabled                                                                          |
|      |          | 1     | Interrupt request enabled                                                                           |
| 0    | AL       |       | Arbitration-lost interrupt enable bit                                                               |
|      |          | 0     | Interrupt request disabled                                                                          |
|      |          | 1     | Interrupt request enabled                                                                           |

# 9.5.4 I2C Status Register (I2CSTR)

The I2C status register (I2CSTR) is a 16-bit register used to determine which interrupt has occurred and to read status information. The bits of I2CSTR are shown and described in Figure 9-19 and Table 9-10, respectively.



#### I2C Module Registers

| Figure 9-19. I2C Status Register (I2CSTR) |         |         |      |         |         |         |         |  |  |  |
|-------------------------------------------|---------|---------|------|---------|---------|---------|---------|--|--|--|
| 15                                        | 14      | 13      | 12   | 11      | 10      | 9       | 8       |  |  |  |
| Reserved                                  | SDIR    | NACKSNT | BB   | RSFULL  | XSMT    | AAS     | AD0     |  |  |  |
| R-0                                       | R/W1C-0 | R/W1C-0 | R-0  | R-0     | R-1     | R-0     | R-0     |  |  |  |
| 7 6                                       |         | 5       | 4    | 3       | 2       | 1       | 0       |  |  |  |
| Reserved                                  |         | SCD     | XRDY | RRDY    | ARDY    | NACK    | AL      |  |  |  |
| R                                         | -0      | R/W1C-0 | R-1  | R/W1C-0 | R/W1C-0 | R/W1C-0 | R/W1C-0 |  |  |  |

LEGEND: R/W = Read/Write; W1C = Write 1 to clear (writing 0 has no effect); R = Read only; -n = value after reset

#### Table 9-10. I2C Status Register (I2CSTR) Field Descriptions

| Bit | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | Reserved | 0     | This reserved bit location is always read as zeros. A value written to this bit has no effect.                                                                                                                                                                                                                                                                                                                                                                 |
| 14  | SDIR     |       | Slave direction bit                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |          | 0     | I2C is not addressed as a slave transmitter. SDIR is cleared by one of the following events:                                                                                                                                                                                                                                                                                                                                                                   |
|     |          |       | • It is manually cleared. To clear this bit, write a 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |          |       | Digital loopback mode is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|     |          |       | A START or STOP condition occurs on the I2C bus.                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |          | 1     | I2C is addressed as a slave transmitter.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13  | NACKSNT  |       | NACK sent bit. This bit is used when the I2C module is in the receiver mode. One instance in which NACKSNT is affected is when the NACK mode is used (see the description for NACKMOD in Section 9.5.1).                                                                                                                                                                                                                                                       |
|     |          | 0     | NACK not sent. NACKSNT bit is cleared by any one of the following events:                                                                                                                                                                                                                                                                                                                                                                                      |
|     |          |       | • It is manually cleared. To clear this bit, write a 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |          |       | <ul> <li>The I2C module is reset (either when 0 is written to the IRS bit of I2CMDR or when the whole<br/>device is reset).</li> </ul>                                                                                                                                                                                                                                                                                                                         |
|     |          | 1     | NACK sent: A no-acknowledge bit was sent during the acknowledge cycle on the I2C-bus.                                                                                                                                                                                                                                                                                                                                                                          |
| 12  | BB       |       | Bus busy bit. BB indicates whether the I2C-bus is busy or is free for another data transfer. See the paragraph following the table for more information.                                                                                                                                                                                                                                                                                                       |
|     |          | 0     | Bus free. BB is cleared by any one of the following events:                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |          |       | • The I2C module receives or transmits a STOP bit (bus free).                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |          |       | The I2C module is reset.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |          | 1     | Bus busy: The I2C module has received or transmitted a START bit on the bus.                                                                                                                                                                                                                                                                                                                                                                                   |
| 11  | RSFULL   |       | Receive shift register full bit. RSFULL indicates an overrun condition during reception. Overrun occurs when new data is received into the shift register (I2CRSR) and the old data has not been read from the receive register (I2CDRR). As new bits arrive from the SDA pin, they overwrite the bits in I2CRSR. The new data will not be copied to ICDRR until the previous data is read.                                                                    |
|     |          | 0     | No overrun detected. RSFULL is cleared by any one of the following events:                                                                                                                                                                                                                                                                                                                                                                                     |
|     |          |       | • I2CDRR is read is read by the CPU. Emulator reads of the I2CDRR do not affect this bit.                                                                                                                                                                                                                                                                                                                                                                      |
|     |          |       | The I2C module is reset.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |          | 1     | Overrun detected                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10  | XSMT     |       | Transmit shift register empty bit. XSMT = 0 indicates that the transmitter has experienced underflow. Underflow occurs when the transmit shift register (I2CXSR) is empty but the data transmit register (I2CDXR) has not been loaded since the last I2CDXR-to-I2CXSR transfer. The next I2CDXR-to-I2CXSR transfer will not occur until new data is in I2CDXR. If new data is not transferred in time, the previous data may be re-transmitted on the SDA pin. |
|     |          | 0     | Underflow detected (empty)                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|     |          | 1     | No underflow detected (not empty). XSMT is set by one of the following events:                                                                                                                                                                                                                                                                                                                                                                                 |
|     |          |       | Data is written to I2CDXR.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|     |          |       | The I2C module is reset                                                                                                                                                                                                                                                                                                                                                                                                                                        |



| Bit | Field    | Value |                                                                                                                                                                                                                                                                                                                                                                        |
|-----|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | AAS      |       | Addressed-as-slave bit                                                                                                                                                                                                                                                                                                                                                 |
|     |          | 0     | In the 7-bit addressing mode, the AAS bit is cleared when receiving a NACK, a STOP condition, or a repeated START condition. In the 10-bit addressing mode, the AAS bit is cleared when receiving a NACK, a STOP condition, or by a slave address different from the I2C peripheral's own slave address.                                                               |
|     |          | 1     | The I2C module has recognized its own slave address or an address of all zeros (general call). The AAS bit is also set if the first byte has been received in the free data format (FDF = 1 in I2CMDR).                                                                                                                                                                |
| 8   | AD0      |       | Address 0 bits                                                                                                                                                                                                                                                                                                                                                         |
|     |          | 0     | AD0 has been cleared by a START or STOP condition.                                                                                                                                                                                                                                                                                                                     |
|     |          | 1     | An address of all zeros (general call) is detected.                                                                                                                                                                                                                                                                                                                    |
| 7-6 | Reserved | 0     | These reserved bit locations are always read as zeros. A value written to this field has no effect.                                                                                                                                                                                                                                                                    |
| 5   | SCD      |       | Stop condition detected bit. SCD is set when the I2C sends or receives a STOP condition. The I2C module delays clearing of the I2CMDR[STP] bit until the SCD bit is set.                                                                                                                                                                                               |
|     |          | 0     | STOP condition not detected since SCD was last cleared. SCD is cleared by any one of the following events:                                                                                                                                                                                                                                                             |
|     |          |       | <ul> <li>I2CISRC is read by the CPU when it contains the value 110b (stop condition detected). Emulator<br/>reads of the I2CISRC do not affect this bit.</li> </ul>                                                                                                                                                                                                    |
|     |          |       | • SCD is manually cleared. To clear this bit, write a 1 to it.                                                                                                                                                                                                                                                                                                         |
|     |          |       | The I2C module is reset.                                                                                                                                                                                                                                                                                                                                               |
|     |          | 1     | A STOP condition has been detected on the I2C bus.                                                                                                                                                                                                                                                                                                                     |
| 4   | XRDY     |       | Transmit-data-ready interrupt flag bit. When not in FIFO mode, XRDY indicates that the data transmit register (I2CDXR) is ready to accept new data because the previous data has been copied from I2CDXR to the transmit shift register (I2CXSR). The CPU can poll XRDY or use the XRDY interrupt request (see Section 9.3.1). When in FIFO mode, use TXFFINT instead. |
|     |          | 0     | I2CDXR not ready. XRDY is cleared when data is written to I2CDXR.                                                                                                                                                                                                                                                                                                      |
|     |          | 1     | I2CDXR ready: Data has been copied from I2CDXR to I2CXSR.                                                                                                                                                                                                                                                                                                              |
|     |          |       | XRDY is also forced to 1 when the I2C module is reset.                                                                                                                                                                                                                                                                                                                 |
| 3   | RRDY     |       | Receive-data-ready interrupt flag bit. When not in FIFO mode, RRDY indicates that the data receive register (I2CDRR) is ready to be read because data has been copied from the receive shift register (I2CRSR) to I2CDRR. The CPU can poll RRDY or use the RRDY interrupt request (see Section 9.3.1). When in FIFO mode, use RXFFINT instead.                         |
|     |          | 0     | I2CDRR not ready. RRDY is cleared by any one of the following events:                                                                                                                                                                                                                                                                                                  |
|     |          |       | I2CDRR is read by the CPU. Emulator reads of the I2CDRR do not affect this bit.                                                                                                                                                                                                                                                                                        |
|     |          |       | RRDY is manually cleared. To clear this bit, write a 1 to it.                                                                                                                                                                                                                                                                                                          |
|     |          |       | The I2C module is reset.                                                                                                                                                                                                                                                                                                                                               |
|     |          | 1     | I2CDRR ready: Data has been copied from I2CRSR to I2CDRR.                                                                                                                                                                                                                                                                                                              |
| 2   | ARDY     |       | Register-access-ready interrupt flag bit (only applicable when the I2C module is in the master mode). ARDY indicates that the I2C module registers are ready to be accessed because the previously programmed address, data, and command values have been used. The CPU can poll ARDY or use the ARDY interrupt request (see Section 9.3.1)                            |
|     |          | 0     | The registers are not ready to be accessed. ARDY is cleared by any one of the following events:                                                                                                                                                                                                                                                                        |
|     |          |       | The I2C module starts using the current register contents.                                                                                                                                                                                                                                                                                                             |
|     |          |       | ARDY is manually cleared. To clear this bit, write a 1 to it.                                                                                                                                                                                                                                                                                                          |
|     |          |       | The I2C module is reset.                                                                                                                                                                                                                                                                                                                                               |
|     |          | 1     | The registers are ready to be accessed.                                                                                                                                                                                                                                                                                                                                |
|     |          |       | In the nonrepeat mode (RM = 0 in I2CMDR): If STP = 0 in I2CMDR, the ARDY bit is set when the internal data counter counts down to 0. If STP = 1, ARDY is not affected (instead, the I2C module generates a STOP condition when the counter reaches 0).                                                                                                                 |
|     |          |       | In the repeat mode (RM = 1): ARDY is set at the end of each byte transmitted from I2CDXR.                                                                                                                                                                                                                                                                              |

# Table 9-10. I2C Status Register (I2CSTR) Field Descriptions (continued)



| www.u.com | www.ti.com |  |
|-----------|------------|--|
|-----------|------------|--|

| Bit | Field | Value | Description                                                                                                                                                                                                                                                                                                           |
|-----|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | NACK  |       | No-acknowledgment interrupt flag bit. NACK applies when the I2C module is a transmitter (master or slave). NACK indicates whether the I2C module has detected an acknowledge bit (ACK) or a no-acknowledge bit (NACK) from the receiver. The CPU can poll NACK or use the NACK interrupt request (see Section 9.3.1). |
|     |       | 0     | ACK received/NACK not received. This bit is cleared by any one of the following events:                                                                                                                                                                                                                               |
|     |       |       | An acknowledge bit (ACK) has been sent by the receiver.                                                                                                                                                                                                                                                               |
|     |       |       | NACK is manually cleared. To clear this bit, write a 1 to it.                                                                                                                                                                                                                                                         |
|     |       |       | <ul> <li>The CPU reads the interrupt source register (I2CISRC) and the register contains the code for a NACK interrupt. Emulator reads of the I2CISRC do not affect this bit.</li> <li>The I2C module is reset.</li> </ul>                                                                                            |
|     |       | 1     | NACK bit received. The hardware detects that a no-acknowledge (NACK) bit has been received.                                                                                                                                                                                                                           |
|     |       | '     |                                                                                                                                                                                                                                                                                                                       |
|     |       |       | Note: While the I2C module performs a general call transfer, NACK is 1, even if one or more slaves send acknowledgment.                                                                                                                                                                                               |
| 0   | AL    |       | Arbitration-lost interrupt flag bit (only applicable when the I2C module is a master-transmitter). AL primarily indicates when the I2C module has lost an arbitration contest with another master-transmitter. The CPU can poll AL or use the AL interrupt request (see Section 9.3.1)                                |
|     |       | 0     | Arbitration not lost. AL is cleared by any one of the following events:                                                                                                                                                                                                                                               |
|     |       |       | AL is manually cleared. To clear this bit, write a 1 to it.                                                                                                                                                                                                                                                           |
|     |       |       | • The CPU reads the interrupt source register (I2CISRC) and the register contains the code for an AL interrupt. Emulator reads of the I2CISRC do not affect this bit.                                                                                                                                                 |
|     |       |       | The I2C module is reset.                                                                                                                                                                                                                                                                                              |
|     |       | 1     | Arbitration lost. AL is set by any one of the following events:                                                                                                                                                                                                                                                       |
|     |       |       | • The I2C module senses that it has lost an arbitration with two or more competing transmitters that started a transmission almost simultaneously.                                                                                                                                                                    |
|     |       |       | • The I2C module attempts to start a transfer while the BB (bus busy) bit is set to 1.                                                                                                                                                                                                                                |
|     |       |       | When AL becomes 1, the MST and STP bits of I2CMDR are cleared, and the I2C module becomes a slave-receiver.                                                                                                                                                                                                           |

#### Table 9-10. I2C Status Register (I2CSTR) Field Descriptions (continued)

The I2C peripheral cannot detect a START or STOP condition when it is in reset, that is, the IRS bit is set to 0. Therefore, the BB bit will remain in the state it was at when the peripheral was placed in reset. The BB bit will stay in that state until the I2C peripheral is taken out of reset, that is, the IRS bit is set to 1, and a START or STOP condition is detected on the I2C bus.

Follow these steps before initiating the first data transfer with I2C :

- After taking the I2C peripheral out of reset by setting the IRS bit to 1, wait a certain period to detect the actual bus status before starting the first data transfer. Set this period larger than the total time taken for the longest data transfer in the application. By waiting for a period of time after I2C comes out of reset, users can ensure that at least one START or STOP condition will have occurred on the I2C bus, and been captured by the BB bit. After this period, the BB bit will correctly reflect the state of the I2C bus.
- 2. Check the BB bit and verify that BB=0 (bus not busy) before proceeding.
- 3. Begin data transfers.

Not resetting the I2C peripheral in between transfers ensures that the BB bit reflects the actual bus status. If users must reset the I2C peripheral in between transfers, repeat steps 1 through 3 every time the I2C peripheral is taken out of reset.

# 9.5.5 I2C Interrupt Source Register (I2CISRC)

The I2C interrupt source register (I2CISRC) is a 16-bit register used by the CPU to determine which event generated the I2C interrupt. For more information about these events, see the descriptions of the I2C interrupt requests in Table 9-3.



|                                                      | I2C Module Registers |
|------------------------------------------------------|----------------------|
| Figure 9-20. I2C Interrupt Source Register (I2CISRC) |                      |

| 15        |  | 12 | 11       |  | 8   | 7        |  | 3   | 2       |  | 0 |
|-----------|--|----|----------|--|-----|----------|--|-----|---------|--|---|
| Reserved  |  | F  | Reserved |  |     | Reserved |  |     | INTCODE |  |   |
| R-0 R/W-0 |  |    |          |  | R-0 |          |  | R-0 |         |  |   |
|           |  |    |          |  |     |          |  |     |         |  |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 9-11. I2C Interrupt Source Register (I2CISRC) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                          |
|-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Reserved |       | These reserved bit locations are always read as zeros. A value written to this field has no effect.                                                                                                  |
| 11-8  | Reserved |       | These reserved bit locations should always be written as zeros.                                                                                                                                      |
| 7-3   | Reserved |       | These reserved bit locations are always read as zeros. A value written to this field has no effect.                                                                                                  |
| 2-0   | INTCODE  |       | Interrupt code bits. The binary code in INTCODE indicates the event that generated an I2C interrupt.                                                                                                 |
|       |          | 000   | None                                                                                                                                                                                                 |
|       |          | 001   | Arbitration lost                                                                                                                                                                                     |
|       |          | 010   | No-acknowledgment condition detected                                                                                                                                                                 |
|       |          | 011   | Registers ready to be accessed                                                                                                                                                                       |
|       |          | 100   | Receive data ready                                                                                                                                                                                   |
|       |          | 101   | Transmit data ready                                                                                                                                                                                  |
|       |          | 110   | Stop condition detected                                                                                                                                                                              |
|       |          | 111   | Addressed as slave                                                                                                                                                                                   |
|       |          |       | A CPU read will clear this field. If another lower priority interrupt is pending and enabled, the value corresponding to that interrupt will then be loaded. Otherwise, the value will stay cleared. |
|       |          |       | In the case of an arbitration lost, a no-acknowledgment condition detected, or a stop condition detected, a CPU read will also clear the associated interrupt flag bit in the I2CSTR register.       |
|       |          |       | Emulator reads will not affect the state of this field or of the status bits in the I2CSTR register.                                                                                                 |

# 9.5.6 I2C Prescaler Register (I2CPSC)

The I2C prescaler register (I2CPSC) is a 16-bit register (see Figure 9-21) used for dividing down the I2C input clock to obtain the desired module clock for the operation of the I2C module. See the device-specific data manual for the supported range of values for the module clock frequency. Table 9-12 lists the bit descriptions. For more details about the module clock, see Section 9.1.3.

IPSC must be initialized while the I2C module is in reset (IRS = 0 in I2CMDR). The prescaled frequency takes effect only when IRS is changed to 1. Changing the IPSC value while IRS = 1 has no effect.

| Figure 9-21 | . I2C | Prescaler | Register | (I2CPSC) |
|-------------|-------|-----------|----------|----------|
|-------------|-------|-----------|----------|----------|

| 15 8     | 7 0   |
|----------|-------|
| Reserved | IPSC  |
| R-0      | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

| Bit  | Field    | Value | Description                                                                                         |
|------|----------|-------|-----------------------------------------------------------------------------------------------------|
| 15-8 | Reserved |       | These reserved bit locations are always read as zeros. A value written to this field has no effect. |
| 7-0  | IPSC     |       | I2C prescaler divide-down value.                                                                    |
|      |          |       | IPSC determines how much the CPU clock is divided to create the module clock of the I2C module:     |
|      |          |       | module clock frequency = I2C input clock frequency/(IPSC + 1)                                       |
|      |          |       | Note: IPSC must be initialized while the I2C module is in reset (IRS = 0 in I2CMDR).                |

#### Table 9-12. I2C Prescaler Register (I2CPSC) Field Descriptions

**NOTE:** To meet all of the I2C protocol timing specifications, the module clock must be configured between 7-12 MHz.

# 9.5.7 I2C Clock Divider Registers (I2CCLKL and I2CCLKH)

As explained in Section 9.1.3, when the I2C module is a master, the module clock is divided down for use as the master clock on the SCL pin. As shown in Figure 9-22, the shape of the master clock depends on two divide-down values:

- ICCL in I2CCLKL (summarized by Figure 9-23 and Table 9-13). For each master clock cycle, ICCL determines the amount of time the signal is low.
- ICCH in I2CCLKH (summarized by Figure 9-24 and Table 9-14). For each master clock cycle, ICCH determines the amount of time the signal is high.

# Figure 9-22. The Roles of the Clock Divide-Down Values (ICCL and ICCH)



A As described in Section 9.5.7.1, Tmod is the module clock period, and d is 5, 6, or 7.

# Figure 9-23. I2C Clock Low-Time Divider Register (I2CCLKL)

| 15    | 0 |
|-------|---|
| ICCL  |   |
| R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 9-13. I2C Clock Low-Time Divider Register (I2CCLKL) Field Description

| Bit | Field | Value | Description                                                                                                                                                                                             |
|-----|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |       |       | Clock low-time divide-down value. To produce the low-time duration of the master clock, the period of the module clock is multiplied by $(ICCL + d)$ . d is 5, 6, or 7 as described in Section 9.5.7.1. |
|     |       |       | Note: These bits must be set to a non-zero value for proper I2C clock operation.                                                                                                                        |

# Figure 9-24. I2C Clock High-Time Divider Register (I2CCLKH)

| 15    | 0 |
|-------|---|
| ICCH  |   |
| R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 9-14. I2C Clock High-Time Divider Register (I2CCLKH) Field Description

| Bit  | Field | Value                                                                                                                                                                                      | Description                                                                      |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| 15-0 | ICCH  | CCH Clock high-time divide-down value. To produce the high-time duration of the mast period of the module clock is multiplied by (ICCH + d). d is 5, 6, or 7 as described Section 9.5.7.1. |                                                                                  |
|      |       |                                                                                                                                                                                            | Note: These bits must be set to a non-zero value for proper I2C clock operation. |



#### 9.5.7.1 Formula for the Master Clock Period

The period of the master clock (Tmst) is a multiple of the period of the module clock (Tmod):

$$T_{mst} = T_{mod} \times [(ICCL + d) + (ICCH + d)]$$
$$T_{mst} = \frac{(IPSC + 1) [(ICCL + d) + (ICCH + d)]}{I2C \text{ input clock frequency}}$$

where d depends on the divide-down value IPSC, as shown in Table 9-15. IPSC is described in Section 9.5.6.

| IPSC           | d |
|----------------|---|
| 0              | 7 |
| 1              | 6 |
| Greater than 1 | 5 |

#### Table 9-15. Dependency of Delay d on the Divide-Down Value IPSC

# 9.5.8 I2C Slave Address Register (I2CSAR)

The I2C slave address register (I2CSAR) is a register for storing the next slave address that will be transmitted by the I2C module when it is a master. It is a 16-bit register with the format shown in Figure 9-25. As described in Table 9-16, the SAR field of I2CSAR contains a 7-bit or 10-bit slave address. When the I2C module is not using the free data format (FDF = 0 in I2CMDR), it uses this address to initiate data transfers with a slave or slaves. When the address is nonzero, the address is for a particular slave. When the address is 0, the address is a general call to all slaves. If the 7-bit addressing mode is selected (XA = 0 in I2CMDR), only bits 6-0 of I2CSAR are used; write 0s to bits 9-7.

| Figure 9-25. | I2C Slave Add | Iress Register | (I2CSAR) |
|--------------|---------------|----------------|----------|
|--------------|---------------|----------------|----------|

| 15       | 10 | 9 | 0        |
|----------|----|---|----------|
| Reserved |    |   | SAR      |
| R-0      |    |   | R/W-3FFh |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Bit   | Field    | Value   | Description                                                                                                                                 |
|-------|----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | Reserved |         | These reserved bit locations are always read as zeros. A value written to this field has no effect.                                         |
| 9-0   | SAR      |         | In 7-bit addressing mode (XA = 0 in I2CMDR):                                                                                                |
|       |          | 00h-7Fh | Bits 6-0 provide the 7-bit slave address that the I2C module transmits when it is in the master-<br>transmitter mode. Write 0s to bits 9-7. |
|       |          |         | In 10-bit addressing mode (XA = 1 in I2CMDR):                                                                                               |

#### Table 9-16. I2C Slave Address Register (I2CSAR) Field Descriptions

# 9.5.9 I2C Own Address Register (I2COAR)

000h-3FFh

transmitter mode.

The I2C own address register (I2COAR) is a 16-bit register. Figure 9-26 shows the format of I2COAR, and Table 9-17 describes its bit fields. The I2C module uses this register to specify its own slave address, which distinguishes it from other slaves connected to the I2C-bus. If the 7-bit addressing mode is selected (XA = 0 in I2CMDR), only bits 6-0 are used; write 0s to bits 9-7.

Bits 9-0 provide the 10-bit slave address that the I2C module transmits when it is in the master-



# I2C Module Registers www.ti.com Figure 9-26. I2C Own Address Register (I2COAR) 0 15 10 9 0 Reserved OAR 0

R-0

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 9-17. I2C Own Address Register (I2COAR) Field Descriptions

R/W-0

| Bit   | Field    | Value     | Description                                                                                         |  |
|-------|----------|-----------|-----------------------------------------------------------------------------------------------------|--|
| 15-10 | Reserved |           | These reserved bit locations are always read as zeros. A value written to this field has no effect. |  |
| 9-0   | OAR      |           | In 7-bit addressing mode (XA = 0 in I2CMDR):                                                        |  |
|       |          | 00h-7Fh   | Bits 6-0 provide the 7-bit slave address of the I2C module. Write 0s to bits 9-7.                   |  |
|       |          |           | In 10-bit addressing mode (XA = 1 in I2CMDR):                                                       |  |
|       |          | 000h-3FFh | Bits 9-0 provide the 10-bit slave address of the I2C module.                                        |  |

# 9.5.10 I2C Data Count Register (I2CCNT)

I2CCNT is a 16-bit register used to indicate how many data bytes to transfer when the I2C module is configured as a transmitter, or to receive when configured as a master receiver. In the repeat mode (RM = 1), I2CCNT is not used. The bits of I2CCNT are shown and described in Figure 9-27 and Table 9-18, respectively.

The value written to I2CCNT is copied to an internal data counter. The internal data counter is decremented by 1 for each byte transferred (I2CCNT remains unchanged). If a STOP condition is requested in the master mode (STP = 1 in I2CMDR), the I2C module terminates the transfer with a STOP condition when the countdown is complete (that is, when the last byte has been transferred).

#### Figure 9-27. I2C Data Count Register (I2CCNT)

| 15    | 0 |
|-------|---|
| ICDC  |   |
| R/W-0 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

| Table 9-18. 12 | 2C Data | Count Register | (I2CCNT) | Field Descriptions |  |
|----------------|---------|----------------|----------|--------------------|--|
|                |         |                |          |                    |  |

| Bit  | Field | Value       | Description                                                                                                                                                  |
|------|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | ICDC  |             | Data count value. ICDC indicates the number of data bytes to transfer or receive. The value in I2CCNT is a don't care when the RM bit in I2CMDR is set to 1. |
|      |       | 0000h       | The start value loaded to the internal data counter is 65536.                                                                                                |
|      |       | 0001h-FFFFh | The start value loaded to internal data counter is 1-65535.                                                                                                  |

# 9.5.11 I2C Data Receive Register (I2CDRR)

I2CDRR (see Figure 9-28 and Table 9-19) is a 16-bit register used by the CPU to read received data. The I2C module can receive a data byte with 1 to 8 bits. The number of bits is selected with the bit count (BC) bits in I2CMDR. One bit at a time is shifted in from the SDA pin to the receive shift register (I2CRSR). When a complete data byte has been received, the I2C module copies the data byte from I2CRSR to I2CDRR. The CPU cannot access I2CRSR directly.

If a data byte with fewer than 8 bits is in I2CDRR, the data value is right-justified, and the other bits of I2CDRR(7-0) are undefined. For example, if BC = 011 (3-bit data size), the receive data is in I2CDRR(2-0), and the content of I2CDRR(7-3) is undefined.

When in the receive FIFO mode, the I2CDRR register acts as the receive FIFO buffer.



R-0

|    | Figure 9-28. I2C Data | Receive Register (I2CDRR) |   |
|----|-----------------------|---------------------------|---|
| 15 | 8                     | 7                         | 0 |
|    | Reserved              | DATA                      |   |

R-0 LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 9-19. I2C Data Receive Register (I2CDRR) Field Descriptions

| Bit  | Field    | Value | Description                                                                                         |
|------|----------|-------|-----------------------------------------------------------------------------------------------------|
| 15-8 | Reserved |       | These reserved bit locations are always read as zeros. A value written to this field has no effect. |
| 7-0  | DATA     |       | Receive data                                                                                        |

## 9.5.12 I2C Data Transmit Register (I2CDXR)

The CPU writes transmit data to I2CDXR (see Figure 9-29 and Table 9-20). This 16-bit register accepts a data byte with 1 to 8 bits. Before writing to I2CDXR, specify how many bits are in a data byte by loading the appropriate value into the bit count (BC) bits of I2CMDR. When writing a data byte with fewer than 8 bits, make sure the value is right-aligned in I2CDXR.

After a data byte is written to I2CDXR, the I2C module copies the data byte to the transmit shift register (I2CXSR). The CPU cannot access I2CXSR directly. From I2CXSR, the I2C module shifts the data byte out on the SDA pin, one bit at a time.

When in the transmit FIFO mode, the I2CDXR register acts as the transmit FIFO buffer.

## Figure 9-29. I2C Data Transmit Register (I2CDXR)

| 15 8     | 7 0   |
|----------|-------|
| Reserved | DATA  |
| R-0      | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 9-20. I2C Data Transmit Register (I2CDXR) Field Descriptions

| Bit  | Field    | Value | Description                                                                                         |
|------|----------|-------|-----------------------------------------------------------------------------------------------------|
| 15-8 | Reserved |       | These reserved bit locations are always read as zeros. A value written to this field has no effect. |
| 7-0  | DATA     |       | Transmit data                                                                                       |

## 9.5.13 I2C Transmit FIFO Register (I2CFFTX)

The I2C transmit FIFO register (I2CFFTX) is a 16-bit register that contains the I2C FIFO mode enable bit as well as the control and status bits for the transmit FIFO mode of operation on the I2C peripheral. The bit fields are shown in Figure 9-30 and described in Table 9-21.

|          |            | i igure 3- | 50. 120 mans |         |         | ~)      |         |
|----------|------------|------------|--------------|---------|---------|---------|---------|
| 15       | 14         | 13         | 12           | 11      | 10      | 9       | 8       |
| Reserved | I2CFFEN    | TXFFRST    | TXFFST4      | TXFFST3 | TXFFST2 | TXFFST1 | TXFFST0 |
| R-0      | R/W-0      | R/W-0      | R-0          | R-0     | R-0     | R-0     | R-0     |
| 7        | 6          | 5          | 4            | 3       | 2       | 1       | 0       |
| TXFFINT  | TXFFINTCLR | TXFFIENA   | TXFFIL4      | TXFFIL3 | TXFFIL2 | TXFFIL1 | TXFFIL0 |
| R-0      | R/W1C-0    | R/W-0      | R/W-0        | R/W-0   | R/W-0   | R/W-0   | R/W-0   |
|          | -          |            |              |         |         |         |         |

## Figure 9-30. I2C Transmit FIFO Register (I2CFFTX)



| Bit  | Field      | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | Reserved   |       | Reserved. Reads will return a 0, writes have no effect.                                                                                                                                                                                                                                                                                                                                                                       |
| 14   | I2CFFEN    |       | I2C FIFO mode enable bit. This bit must be enabled for either the transmit or the receive FIFO to operate correctly.                                                                                                                                                                                                                                                                                                          |
|      |            | 0     | Disable the I2C FIFO mode.                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |            | 1     | Enable the I2C FIFO mode.                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13   | TXFFRST    |       | I2C transmit FIFO reset bit.                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |            | 0     | Reset the transmit FIFO pointer to 0000 and hold the transmit FIFO in the reset state.                                                                                                                                                                                                                                                                                                                                        |
|      |            | 1     | Enable the transmit FIFO operation.                                                                                                                                                                                                                                                                                                                                                                                           |
| 12-8 | TXFFST4-0  |       | Contains the status of the transmit FIFO:                                                                                                                                                                                                                                                                                                                                                                                     |
|      |            | 00xxx | Transmit FIFO contains xxx bytes.                                                                                                                                                                                                                                                                                                                                                                                             |
|      |            | 00000 | Transmit FIFO is empty.                                                                                                                                                                                                                                                                                                                                                                                                       |
|      |            |       | Note: Since these bits are reset to zero, the transmit FIFO interrupt flag will be set when the transmit FIFO operation is enabled and the I2C is taken out of reset. This will generate a transmit FIFO interrupt if enabled. To avoid any detrimental effects from this, write a one to the TXFFINTCLR once the transmit FIFO operation is enabled and the I2C is taken out of reset.                                       |
| 7    | TXFFINT    |       | Transmit FIFO interrupt flag. This bit cleared by a CPU write of a 1 to the TXFFINTCLR bit. If the TXFFIENA bit is set, this bit will generate an interrupt when it is set.                                                                                                                                                                                                                                                   |
|      |            | 0     | Transmit FIFO interrupt condition has not occurred.                                                                                                                                                                                                                                                                                                                                                                           |
|      |            | 1     | Transmit FIFO interrupt condition has occurred.                                                                                                                                                                                                                                                                                                                                                                               |
| 6    | TXFFINTCLR |       | Transmit FIFO interrupt flag clear bit.                                                                                                                                                                                                                                                                                                                                                                                       |
|      |            | 0     | Writes of zeros have no effect. Reads return a 0.                                                                                                                                                                                                                                                                                                                                                                             |
|      |            | 1     | Writing a 1 to this bit clears the TXFFINT flag.                                                                                                                                                                                                                                                                                                                                                                              |
| 5    | TXFFIENA   |       | Transmit FIFO interrupt enable bit.                                                                                                                                                                                                                                                                                                                                                                                           |
|      |            | 0     | Disabled. TXFFINT flag does not generate an interrupt when set.                                                                                                                                                                                                                                                                                                                                                               |
|      |            | 1     | Enabled. TXFFINT flag does generate an interrupt when set.                                                                                                                                                                                                                                                                                                                                                                    |
| 4-0  | TXFFIL4-0  |       | Transmit FIFO interrupt level.                                                                                                                                                                                                                                                                                                                                                                                                |
|      |            |       | These bits set the status level that will set the transmit interrupt flag. When the TXFFST4-0 bits reach a value equal to or less than these bits, the TXFFINT flag will be set. This will generate an interrupt if the TXFFIENA bit is set. Because the I2C on these devices has a 4-level transmit FIFO, these bits cannot be configured for an interrupt of more than 4 FIFO levels. TXFFIL4 and TXFFIL3 are tied to zero. |

## Table 9-21. I2C Transmit FIFO Register (I2CFFTX) Field Descriptions

## 9.5.14 I2C Receive FIFO Register (I2CFFRX)

The I2C receive FIFO register (I2CFFRX) is a 16-bit register that contains the control and status bits for the receive FIFO mode of operation on the I2C peripheral. The bit fields are shown in Figure 9-31 and described in Table 9-22.

|         |            | Figure 9 | -31. 120 Neve | ive fift key |         | <b>^</b> ) |         |
|---------|------------|----------|---------------|--------------|---------|------------|---------|
| 15      | 14         | 13       | 12            | 11           | 10      | 9          | 8       |
| Res     | erved      | RXFFRST  | RXFFST4       | RXFFST3      | RXFFST2 | RXFFST1    | RXFFST0 |
| F       | R-0        | R/W-0    | R-0           | R-0          | R-0     | R-0        | R-0     |
| 7       | 6          | 5        | 4             | 3            | 2       | 1          | 0       |
| RXFFINT | RXFFINTCLR | RXFFIENA | RXFFIL4       | RXFFIL3      | RXFFIL2 | RXFFIL1    | RXFFIL0 |
| R-0     | R/W1C-0    | R/W-0    | R/W-0         | R/W-0        | R/W-0   | R/W-0      | R/W-0   |

## Figure 9-31. I2C Receive FIFO Register (I2CFFRX)



## Table 9-22. I2C Receive FIFO Register (I2CFFRX) Field Descriptions

| Bit   | Field      | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14 | Reserved   |       | Reserved. Reads will return a 0, writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13    | RXFFRST    |       | I2C receive FIFO reset bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |            | 0     | Reset the receive FIFO pointer to 0000 and hold the receive FIFO in the reset state.                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |            | 1     | Enable the receive FIFO operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 12-8  | RXFFST4-0  |       | Contains the status of the receive FIFO:                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |            | 00xxx | Receive FIFO contains xxx bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |            | 00000 | Receive FIFO is empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7     | RXFFINT    |       | Receive FIFO interrupt flag. This bit cleared by a CPU write of a 1 to the RXFFINTCLR bit. If the RXFFIENA bit is set, this bit will generate an interrupt when it is set.                                                                                                                                                                                                                                                                                                                                 |
|       |            | 0     | Receive FIFO interrupt condition has not occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |            | 1     | Receive FIFO interrupt condition has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6     | RXFFINTCLR |       | Receive FIFO interrupt flag clear bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |            | 0     | Writes of zeros have no effect. Reads return a zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |            | 1     | Writing a 1 to this bit clears the RXFFINT flag.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5     | RXFFIENA   |       | Receive FIFO interrupt enable bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |            | 0     | Disabled. RXFFINT flag does not generate an interrupt when set.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |            | 1     | Enabled. RXFFINT flag does generate an interrupt when set.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4-0   | RXFFIL4-0  |       | Receive FIFO interrupt level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |            |       | These bits set the status level that will set the receive interrupt flag. When the RXFFST4-0 bits reach a value equal to or greater than these bits, the RXFFINT flag is set. This will generate an interrupt if the RXFFIENA bit is set.                                                                                                                                                                                                                                                                  |
|       |            |       | Note: Since these bits are reset to zero, the receive FIFO interrupt flag will be set if the receive FIFO operation is enabled and the I2C is taken out of reset. This will generate a receive FIFO interrupt if enabled. To avoid this, modify these bits on the same instruction as or prior to setting the RXFFRST bit. Because the I2C on these devices has a 4-level receive FIFO, these bits cannot be configured for an interrupt of more than 4 FIFO levels. RXFFIL4 and RXFFIL3 are tied to zero. |



Page

# Serial Peripheral Interface (SPI)

The serial peripheral interface (SPI) is a high-speed synchronous serial input/ output (I/O) port that allows a serial bit stream of programmed length (one to sixteen bits) to be shifted into and out of the device at a programmed bit-transfer rate. The SPI is normally used for communications between the DSP controller and external peripherals or another controller. Typical applications include external I/O or peripheral expansion via devices such as shift registers, display drivers, and analog-to-digital converters (ADCs). Multidevice communications are supported by the master/slave operation of the SPI. On the C28x<sup>™</sup>, the port supports a 4 -level, receive and transmit FIFO for reducing CPU servicing overhead.

#### Topic

| 10.1 | Enhanced SPI Module Overview | <b>689</b> |
|------|------------------------------|------------|
| 10.2 | SPI Registers and Waveforms  | 705        |



## 10.1 Enhanced SPI Module Overview

Figure 10-1 shows the SPI CPU interfaces.



Figure 10-1. SPI CPU Interface

The SPI module features include:

- SPISOMI: SPI slave-output/master-input pin
- SPISIMO: SPI slave-input/master-output pin
- SPISTE: SPI slave transmit-enable pin
- SPICLK: SPI serial-clock pin

**NOTE:** All four pins can be used as GPIO, if the SPI module is not used.

- Two operational modes: master and slave
- Baud rate: 125 different programmable rates. The maximum baud rate that can be employed is limited by the maximum speed of the I/O buffers used on the SPI pins. See the device-specific data sheet for more details.
- Data word length: one to sixteen data bits
- Four clocking schemes (controlled by clock polarity and clock phase bits) include:
  - Falling edge without phase delay: SPICLK active-high. SPI transmits data on the falling edge of the SPICLK signal and receives data on the rising edge of the SPICLK signal.
  - Falling edge with phase delay: SPICLK active-high. SPI transmits data one half-cycle ahead of the falling edge of the SPICLK signal and receives data on the falling edge of the SPICLK signal.
  - Rising edge without phase delay: SPICLK inactive-low. SPI transmits data on the rising edge of the SPICLK signal and receives data on the falling edge of the SPICLK signal.
  - Rising edge with phase delay: SPICLK inactive-low. SPI transmits data one half-cycle ahead of the falling edge of the SPICLK signal and receives data on the rising edge of the SPICLK signal.
- Simultaneous receive and transmit operation (transmit function can be disabled in software)
- Transmitter and receiver operations are accomplished through either interrupt- driven or polled algorithms.
- 12 SPI module control registers: Located in control register frame beginning at address 7040h.

**NOTE:** All registers in this module are 16-bit registers that are connected to Peripheral Frame 2. When a register is accessed, the register data is in the lower byte (7–0), and the upper byte (15–8) is read as zeros. Writing to the upper byte has no effect.

#### **Enhanced Features:**

- 4-level transmit/receive FIFO
- Delayed transmit control
- 3-wire SPI mode
- SPISTE inversion for digital audio interface receive mode on devices with 2 SPI modules.

## 10.1.1 SPI Block Diagram

Figure 10-2 is a block diagram of the SPI in slave mode, showing the basic control blocks available on the SPI module.





Figure 10-2. Serial Peripheral Interface Module Block Diagram

A SPISTE of a slave device is driven low by the master.

## 10.1.2 SPI Module Signal Summary

| Table 10-1 | . SPI Module | Signal | Summary |
|------------|--------------|--------|---------|
|------------|--------------|--------|---------|

| Signal Name                    | Description                                                                     |
|--------------------------------|---------------------------------------------------------------------------------|
| External Signals               |                                                                                 |
| SPICLK                         | SPI clock                                                                       |
| SPISIMO/SPIMOMI <sup>(1)</sup> | SPI slave in, master out/ SPI master out, master in                             |
| SPISOMI/SPISISO <sup>(1)</sup> | SPI slave out, master in/ SPI slave in, slave out                               |
| SPISTE                         | SPI slave transmit enable                                                       |
| Control                        |                                                                                 |
| SPI Clock Rate                 | LSPCLK                                                                          |
| Interrupt signals              |                                                                                 |
| SPIRXINT                       | Transmit interrupt/ Receive Interrupt in non FIFO mode (referred to as SPI INT) |
|                                | Receive in interrupt in FIFO mode                                               |
| SPITXINT                       | Transmit interrupt – FIFO                                                       |

<sup>(1)</sup> In 3-wire master mode, the SPISIMO pin becomes the SPIMOMI pin and the SPISOMI pin becomes a general purpose input/output (GPIO) pin. In 3-wire slave mode, the SPISOMI pin becomes the SPISISO pin and the SPISIMO pin becomes a GPIO pin.

## 10.1.3 Overview of SPI Module Registers

The SPI port operation is configured and controlled by the registers listed in Table 10-2.

|          |               | 5          |                                    |
|----------|---------------|------------|------------------------------------|
| Name     | Address Range | Size (x16) | Description                        |
| SPICCR   | 0x0000-7040   | 1          | SPI Configuration Control Register |
| SPICTL   | 0x0000-7041   | 1          | SPI Operation Control Register     |
| SPIST    | 0x0000-7042   | 1          | SPI Status Register                |
| SPIBRR   | 0x0000-7044   | 1          | SPI Baud Rate Register             |
| SPIEMU   | 0x0000-7046   | 1          | SPI Emulation Buffer Register      |
| SPIRXBUF | 0x0000-7047   | 1          | SPI Serial Input Buffer Register   |
| SPITXBUF | 0x0000-7048   | 1          | SPI Serial Output Buffer Register  |
| SPIDAT   | 0x0000-7049   | 1          | SPI Serial Data Register           |
| SPIFFTX  | 0x0000-704A   | 1          | SPI FIFO Transmit Register         |
| SPIFFRX  | 0x0000-704B   | 1          | SPI FIFO Receive Register          |
| SPIFFCT  | 0x0000-704C   | 1          | SPI FIFO Control Register          |
| SPIPRI   | 0x0000-704F   | 1          | SPI Priority Control Register      |

#### Table 10-2. SPI Registers

This SPI has 16-bit transmit and receive capability, with double-buffered transmit and double-buffered receive. All data registers are 16-bits wide.

The SPI is no longer limited to a maximum transmission rate of LSPCLK/8 in slave mode. The maximum transmission rate in both slave mode and master mode is now LSPCLK/4.

Writes of transmit data to the serial data register, SPIDAT (and the new transmit buffer, SPITXBUF), must be left-justified within a 16-bit register.

The control and data bits for general-purpose bit I/O multiplexing have been removed from this peripheral, along with the associated registers, SPIPC1 (704Dh) and SPIPC2 (704Eh). These bits are now in the General-Purpose I/O registers.

Twelve registers inside the SPI module control the SPI operations:

- SPICCR (SPI configuration control register). Contains control bits used for SPI configuration
  - SPI module software reset

Enhanced SPI Module Overview



www.ti.com

- SPICLK polarity selection
- Four SPI character-length control bits
- SPICTL (SPI operation control register). Contains control bits for data transmission
  - Two SPI interrupt enable bits
  - SPICLK phase selection
  - Operational mode (master/slave)
  - Data transmission enable
- SPISTS (SPI status register). Contains two receive buffer status bits and one transmit buffer status bit
  - RECEIVER OVERRUN
  - SPI INT FLAG
  - TX BUF FULL FLAG
- SPIBRR (SPI baud rate register). Contains seven bits that determine the bit transfer rate
- SPIRXEMU (SPI receive emulation buffer register). Contains the received data. This register is used for emulation purposes only. The SPIRXBUF should be used for normal operation
- SPIRXBUF (SPI receive buffer the serial receive buffer register). Contains the received data
- SPITXBUF (SPI transmit buffer the serial transmit buffer register). Contains the next character to be transmitted
- SPIDAT (SPI data register). Contains data to be transmitted by the SPI, acting as the transmit/receive shift register. Data written to SPIDAT is shifted out on subsequent SPICLK cycles. For every bit shifted out of the SPI, a bit from the receive bit stream is shifted into the other end of the shift register
- SPIPRI (SPI priority register). Contains bits that specify interrupt priority and determine SPI operation on the XDS<sup>™</sup> emulator during program suspensions. This register also contains bit to enable 3-wire mode and the SPISTE inversion bit.

## 10.1.4 SPI Operation

This section describes the operation of the SPI. Included are explanations of the operation modes, interrupts, data format, clock sources, and initialization. Typical timing diagrams for data transfers are given.

## 10.1.4.1 Introduction to Operation

Figure 10-3 shows typical connections of the SPI for communications between two controllers: a master and a slave.

The master initiates data transfer by sending the SPICLK signal. For both the slave and the master, data is shifted out of the shift registers on one edge of the SPICLK and latched into the shift register on the opposite SPICLK clock edge. If the CLOCK PHASE bit (SPICTL.3) is high, data is transmitted and received a half-cycle before the SPICLK transition (see Section 10.1.4.2). As a result, both controllers send and receive data simultaneously. The application software determines whether the data is meaningful or dummy data. There are three possible methods for data transmission:

- · Master sends data; slave sends dummy data.
- Master sends data; slave sends data.
- Master sends dummy data; slave sends data.

The master can initiate data transfer at any time because it controls the SPICLK signal. The software, however, determines how the master detects when the slave is ready to broadcast data.





Figure 10-3. SPI Master/Slave Connection

## 10.1.4.2 SPI Module Slave and Master Operation Modes

The SPI can operate in master or slave mode. The MASTER/SLAVE bit (SPICTL.2) selects the operating mode and the source of the SPICLK signal.

#### 10.1.4.2.1 Master Mode

In the master mode (MASTER/SLAVE = 1), the SPI provides the serial clock on the SPICLK pin for the entire serial communications network. Data is output on the SPISIMO pin and latched from the SPISOMI pin.

The SPIBRR register determines both the transmit and receive bit transfer rate for the network. SPIBRR can select 126 different data transfer rates.

Data written to SPIDAT or SPITXBUF initiates data transmission on the SPISIMO pin, MSB (most significant bit) first. Simultaneously, received data is shifted through the SPISOMI pin into the LSB (least significant bit) of SPIDAT. When the selected number of bits has been transmitted, the received data is transferred to the SPIRXBUF (buffered receiver) for the CPU to read. Data is stored right-justified in SPIRXBUF.

When the specified number of data bits has been shifted through SPIDAT, the following events occur:

- SPIDAT contents are transferred to SPIRXBUF.
- SPI INT FLAG bit (SPISTS.6) is set to 1.
- If there is valid data in the transmit buffer SPITXBUF, as indicated by the TXBUF FULL bit in SPISTS, this data is transferred to SPIDAT and is transmitted; otherwise, SPICLK stops after all bits have been shifted out of SPIDAT.
- If the SPI INT ENA bit (SPICTL.0) is set to 1, an interrupt is asserted.

In a typical application, the SPISTE pin serves as a chip-enable pin for a slave SPI device. This pin is driven low by the master before transmitting data to the slave and is taken high after the transmission is complete.

#### 10.1.4.2.2 Slave Mode

In the slave mode (MASTER/SLAVE = 0), data shifts out on the SPISOMI pin and in on the SPISIMO pin. The SPICLK pin is used as the input for the serial shift clock, which is supplied from the external network master. The transfer rate is defined by this clock. The SPICLK input frequency should be no greater than the LSPCLK frequency divided by 4.



Data written to SPIDAT or SPITXBUF is transmitted to the network when appropriate edges of the SPICLK signal are received from the network master. Data written to the SPITXBUF register will be transferred to the SPIDAT register when all bits of the character to be transmitted have been shifted out of SPIDAT. If no character is currently being transmitted when SPITXBUF is written to, the data will be transferred immediately to SPIDAT. To receive data, the SPI waits for the network master to send the SPICLK signal and then shifts the data on the SPISIMO pin into SPIDAT. If data is to be transmitted by the slave simultaneously, and SPITXBUF has not been previously loaded, the data must be written to SPITXBUF or SPIDAT before the beginning of the SPICLK signal.

When the TALK bit (SPICTL.1) is cleared, data transmission is disabled, and the output line (SPISOMI) is put into the high-impedance state. If this occurs while a transmission is active, the current character is completely transmitted even though SPISOMI is forced into the high-impedance state. This ensures that the SPI is still able to receive incoming data correctly. This TALK bit allows many slave devices to be tied together on the network, but only one slave at a time is allowed to drive the SPISOMI line.

The SPISTE pin operates as the slave-select pin. An active-low signal on the SPISTE pin allows the slave SPI to transfer data to the serial data line; an inactive- high signal causes the slave SPI serial shift register to stop and its serial output pin to be put into the high-impedance state. This allows many slave devices to be tied together on the network, although only one slave device is selected at a time.

## 10.1.5 SPI Interrupts

This section includes information on the control bits that initialize interrupts, data format, clocking, initialization, and data transfer.

## 10.1.5.1 SPI Interrupt Control Bits

Five control bits are used to initialize the SPI interrupts:

- SPI INT ENA bit (SPICTL.0)
- SPI INT FLAG bit (SPISTS.6)
- OVERRUN INT ENA bit (SPICTL.4)
- RECEIVER OVERRUN FLAG bit (SPISTS.7)

## 10.1.5.1.1 SPI INT ENA Bit (SPICTL.0)

When the SPI interrupt-enable bit is set and an interrupt condition occurs, the corresponding interrupt is asserted.

- 0 Disable SPI interrupts
- 1 Enable SPI interrupts

## 10.1.5.1.2 SPI INT Flag Bit (SPISTS.6)

This status flag indicates that a character has been placed in the SPI receiver buffer and is ready to be read.

When a complete character has been shifted into or out of SPIDAT, the SPI INT FLAG bit (SPISTS.6) is set, and an interrupt is generated if enabled by the SPI INT ENA bit (SPICTL.0). The interrupt flag remains set until it is cleared by one of the following events:

- The interrupt is acknowledged (this is different from the C240).
- The CPU reads the SPIRXBUF (reading the SPIRXEMU does not clear the SPI INT FLAG bit).
- The device enters IDLE2 or HALT mode with an IDLE instruction.
- Software clears the SPI SW RESET bit (SPICCR.7).
- A system reset occurs.

When the SPI INT FLAG bit is set, a character has been placed into the SPIRXBUF and is ready to be read. If the CPU does not read the character by the time the next complete character has been received, the new character is written into SPIRXBUF, and the RECEIVER OVERRUN Flag bit (SPISTS.7) is set.

#### 10.1.5.1.3 Overrun INT ENA Bit (SPICTL.4)

Setting the overrun interrupt enable bit allows the assertion of an interrupt whenever the RECEIVER OVERRUN Flag bit (SPISTS.7) is set by hardware. Interrupts generated by SPISTS.7 and by the SPI INT FLAG bit (SPISTS.6) share the same interrupt vector.

- 0 Disable RECEIVER OVERRUN Flag bit interrupts
- 1 Enable RECEIVER OVERRUN Flag bit interrupts

#### 10.1.5.1.4 Receiver Overrun Flag Bit (SPISTS.7)

The RECEIVER OVERRUN Flag bit is set whenever a new character is received and loaded into the SPIRXBUF before the previously received character has been read from the SPIRXBUF. The RECEIVER OVERRUN Flag bit must be cleared by software.

#### 10.1.5.2 Data Format

Four bits (SPICCR.3–0) specify the number of bits (1 to 16) in the data character. This information directs the state control logic to count the number of bits received or transmitted to determine when a complete character has been processed. The following statements apply to characters with fewer than 16 bits:

- Data must be left-justified when written to SPIDAT and SPITXBUF.
- Data read back from SPIRXBUF is right-justified.
- SPIRXBUF contains the most recently received character, right-justified, plus any bits that remain from previous transmission(s) that have been shifted to the left (shown in Example 10-1).

#### Example 10-1. Transmission of Bit From SPIRXBUF

Conditions:

- 1. Transmission character length = 1 bit (specified in bits SPICCR.3-0)
- 2. The current value of SPIDAT = 737Bh

| SPIDAT (before transmission)  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |                  |                     |
|-------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------------------|---------------------|
|                               | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1                |                     |
| SPIDAT (after transmission)   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |                  |                     |
| → 0 (TXed) 0                  | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | x <sup>(1)</sup> | $\leftarrow (RXed)$ |
| SPIRXBUF (after transmission) |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |                  |                     |
|                               | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | x <sup>(1)</sup> |                     |

(1) x = 1 if SPISOMI data is high; x = 0 if SPISOMI data is low; master mode is assumed.

(5)

(6)

#### 10.1.5.3 Baud Rate and Clocking Schemes

The SPI module supports 125 different baud rates and four different clock schemes. Depending on whether the SPI clock is in slave or master mode, the SPICLK pin can receive an external SPI clock signal or provide the SPI clock signal, respectively.

- In the slave mode, the SPI clock is received on the SPICLK pin from the external source, and can be no greater than the LSPCLK frequency divided by 4.
- In the master mode, the SPI clock is generated by the SPI and is output on the SPICLK pin, and can be no greater than the LSPCLK frequency divided by 4.

Example 10-2 shows how to determine the SPI baud rates.

## Example 10-2. Baud Rate Determination

For SPIBRR = 3 to 127: SPI Baud Rate =  $\frac{\text{LSPCLK}}{(\text{SPIBRR} + 1)}$ 

For SPIBRR = 0, 1, or 2: SPI Baud Rate = LSPCLK

where:

LSPCLK = Low-speed peripheral clock frequency of the device

SPIBRR = Contents of the SPIBRR in the master SPI device

To determine what value to load into SPIBRR, you must know the device system clock (LSPCLK) frequency (which is device-specific) and the baud rate at which you will be operating.

Example 1–2 shows how to determine the maximum baud rate at which a 240xA can communicate. Assume that LSPCLK = 40 MHz.

#### Example 10-3. Maximum Baud-Rate Calculation

| Maximum SPI Baud Rate = | LSPCLK<br>4                |     |
|-------------------------|----------------------------|-----|
|                         | $\frac{40 \times 10^6}{4}$ |     |
| =                       | 10 ×10 <sup>6</sup> bps    | (7) |

## 10.1.5.3.1 SPI Clocking Schemes

The CLOCK POLARITY bit (SPICCR.6) and the CLOCK PHASE bit (SPICTL.3) control four different clocking schemes on the SPICLK pin. The CLOCK POLARITY bit selects the active edge, either rising or falling, of the clock. The CLOCK PHASE bit selects a half-cycle delay of the clock. The four different clocking schemes are as follows:

- Falling Edge Without Delay. The SPI transmits data on the falling edge of the SPICLK and receives data on the rising edge of the SPICLK.
- Falling Edge With Delay. The SPI transmits data one half-cycle ahead of the falling edge of the SPICLK signal and receives data on the falling edge of the SPICLK signal.
- Rising Edge Without Delay. The SPI transmits data on the rising edge of the SPICLK signal and receives data on the falling edge of the SPICLK signal.
- Rising Edge With Delay. The SPI transmits data one half-cycle ahead of the rising edge of the SPICLK signal and receives data on the rising edge of the SPICLK signal.

The selection procedure for the SPI clocking scheme is shown in Table 10-3. Examples of these four clocking schemes relative to transmitted and received data are shown in Figure 10-4.

| SPICLK Scheme              | CLOCK POLARITY<br>(SPICCR.6) | CLOCK PHASE<br>(SPICTL.3) <sup>(1)</sup> |
|----------------------------|------------------------------|------------------------------------------|
| Rising edge without delay  | 0                            | 0                                        |
| Rising edge with delay     | 0                            | 1                                        |
| Falling edge without delay | 1                            | 0                                        |
| Falling edge with delay    | 1                            | 1                                        |

#### Table 10-3. SPI Clocking Scheme Selection Guide

<sup>(1)</sup> The description of CLOCK PHASE and CLOCK POLARITY differs between manufacturers. For proper operation, select the desired waveform to determine the PHASE and POLARITY settings



#### Figure 10-4. SPICLK Signal Options

**Note:** Previous data bit

For the SPI, SPICLK symmetry is retained only when the result of (SPIBRR+1) is an even value. When (SPIBRR + 1) is an odd value and SPIBRR is greater than 3, SPICLK becomes asymmetrical. The low pulse of SPICLK is one CLKOUT longer than the high pulse when the CLOCK POLARITY bit is clear (0). When the CLOCK POLARITY bit is set to 1, the high pulse of the SPICLK is one CLKOUT longer than the low pulse, as shown in Figure 10-5.

#### Figure 10-5. SPI: SPICLK-CLKOUT Characteristic When (BRR + 1) is Odd, BRR > 3, and CLOCK POLARITY = 1



#### 10.1.5.4 Initialization Upon Reset

A system reset forces the SPI peripheral module into the following default configuration:



- Unit is configured as a slave module (MASTER/SLAVE = 0)
- Transmit capability is disabled (TALK = 0)
- Data is latched at the input on the falling edge of the SPICLK signal
- Character length is assumed to be one bit
- SPI interrupts are disabled
- Data in SPIDAT is reset to 0000h
- SPI module pin functions are selected as general-purpose inputs (this is done in I/O MUX control register B [MCRB])

To change this SPI configuration:

- Step 1. Clear the SPI SW RESET bit (SPICCR.7) to 0 to force the SPI to the reset state.
- Step 2. Initialize the SPI configuration, format, baud rate, and pin functions as desired.
- Step 3. Set the SPI SW RESET bit to 1 to release the SPI from the reset state.
- Step 4. Write to SPIDAT or SPITXBUF (this initiates the communication process in the master).
- Step 5. Read SPIRXBUF after the data transmission has completed (SPISTS.6 = 1) to determine what data was received.

To prevent unwanted and unforeseen events from occurring during or as a result of initialization changes, clear the SPI SW RESET bit (SPICCR.7) before making initialization changes, and then set this bit after initialization is complete.

NOTE: Do not change the SPI configuration when communication is in progress.

## 10.1.5.5 Data Transfer Example

The timing diagram shown in Figure 10-6 illustrates an SPI data transfer between two devices using a character length of five bits with the SPICLK being symmetrical.

The timing diagram with SPICLK unsymmetrical (Figure 10-5) shares similar characterizations with Figure 10-6 except that the data transfer is one CLKOUT cycle longer per bit during the low pulse (CLOCK POLARITY = 0) or during the high pulse (CLOCK POLARITY = 1) of the SPICLK.

Figure 10-6 is applicable for 8-bit SPI only and is not for 24x devices that are capable of working with 16bit data. The figure is shown for illustrative purposes only.



#### Enhanced SPI Module Overview



www.ti.com

| Master SPI<br>Int flag                |                                            |   |
|---------------------------------------|--------------------------------------------|---|
| Slave SPI<br>Int flag                 |                                            |   |
| SPISOMI<br>from slave                 | A B C D E F G H I J<br>7 6 5 4 3 7 6 5 4 3 | K |
| SPISIMO<br>from master                |                                            |   |
| SPICLK signal options:                |                                            |   |
| CLOCK POLARITY = 0<br>CLOCK PHASE = 0 |                                            |   |
| CLOCK POLARITY = 0<br>CLOCK PHASE = 1 |                                            |   |
|                                       |                                            |   |
| CLOCK POLARITY = 1<br>CLOCK PHASE = 0 |                                            |   |
| CLOCK POLARITY = 1<br>CLOCK PHASE = 1 |                                            |   |
| SPISTE                                |                                            |   |

- A Slave writes 0D0h to SPIDAT and waits for the master to shift out the data.
- B Master sets the slave SPISTE signal low (active).
- C Master writes 058h to SPIDAT, which starts the transmission procedure.
- D First byte is finished and sets the interrupt flags.
- E Slave reads 0Bh from its SPIRXBUF (right-justified).
- F Slave writes 04Ch to SPIDAT and waits for the master to shift out the data.
- G Master writes 06Ch to SPIDAT, which starts the transmission procedure.
- H Master reads 01Ah from the SPIRXBUF (right-justified).
- I Second byte is finished and sets the interrupt flags.
- J Master reads 89h and the slave reads 8Dh from their respective SPIRXBUF. After the user's software masks off the unused bits, the master receives 09h and the slave receives 0Dh.
- K Master clears the slave SPISTE signal high (inactive).

## 10.1.6 SPI FIFO Description

The following steps explain the FIFO features and help with programming the SPI FIFOs:

- 1. Reset. At reset the SPI powers up in standard SPI mode, the FIFO function is disabled. The FIFO registers SPIFFTX, SPIFFRX and SPIFFCT remain inactive.
- 2. Standard SPI. The standard 240x SPI mode will work with SPIINT/SPIRXINT as the interrupt source.
- 3. Mode change. FIFO mode is enabled by setting the SPIFFEN bit to 1 in the SPIFFTX register. SPIRST can reset the FIFO mode at any stage of its operation.
- 4. Active registers. All the SPI registers and SPI FIFO registers SPIFFTX, SPIFFRX, and SPIFFCT will be active.
- 5. Interrupts. FIFO mode has two interrupts one for transmit FIFO, SPITXINT and one for receive FIFO, SPIINT/SPIRXINT. SPIINT/SPIRXINT is the common interrupt for SPI FIFO receive, receive error and receive FIFO overflow conditions. The single SPIINT for both transmit and receive sections of the standard SPI will be disabled and this interrupt will service as SPI receive FIFO interrupt.

- 6. Buffers. Transmit and receive buffers are supplemented with two FIFOs. The one-word transmit buffer (TXBUF) of the standard SPI functions as a transition buffer between the transmit FIFO and shift register. The one-word transmit buffer will be loaded from transmit FIFO only after the last bit of the shift register is shifted out.
- 7. Delayed transfer. The rate at which transmit words in the FIFO are transferred to transmit shift register is programmable. The SPIFFCT register bits (7–0) FFTXDLY7–FFTXDLY0 define the delay between the word transfer. The delay is defined in number SPI serial clock cycles. The 8-bit register could define a minimum delay of 0 serial clock cycles and a maximum of 255 serial clock cycles. With zero delay, the SPI module can transmit data in continuous mode with the FIFO words shifting out back to back. With the 255 clock delay, the SPI module can transmit data in a maximum delayed mode with the FIFO words shifting out with a delay of 255 SPI clocks between each words. The programmable delay facilitates glueless interface to various slow SPI peripherals, such as EEPROMs, ADC, DAC etc.
- FIFO status bits. Both transmit and receive FIFOs have status bits TXFFST or RXFFST (bits 12- 0) that define the number of words available in the FIFOs at any time. The transmit FIFO reset bit TXFIFO and receive reset bit RXFIFO will reset the FIFO pointers to zero when these bits are set to 1. The FIFOs will resume operation from start once these bits are cleared to zero.
- 9. Programmable interrupt levels. Both transmit and receive FIFO can generate CPU interrupts. The interrupt trigger is generated whenever the transmit FIFO status bits TXFFST (bits 12–8) match (less than or equal to) the interrupt trigger level bits TXFFIL (bits 4–0). This provides a programmable interrupt trigger for transmit and receive sections of the SPI. The default value for these trigger level bits will be 0x11111 for receive FIFO and 0x00000 for transmit FIFO respectively.

## 10.1.6.1 SPI Interrupts







|                  | SPI Interrupt   | Interrupt | Interrupt  | FIFO Enable | Interrupt <sup>(1)</sup> |
|------------------|-----------------|-----------|------------|-------------|--------------------------|
| FIFO Options     | Source          | Flags     | Enables    | SPIFFENA    | line                     |
| SPI without FIFO |                 |           |            |             |                          |
|                  | Receive overrun | RXOVRN    | OVRNINTENA | 0           | SPIRXINT                 |
|                  | Data receive    | SPIINT    | SPIINTENA  | 0           | SPIRXINT                 |
|                  | Transmit empty  | SPIINT    | SPIINTENA  | 0           | SPIRXINT                 |
| SPI FIFO mode    |                 |           |            |             |                          |
|                  | FIFO receive    | RXFFIL    | RXFFIENA   | 1           | SPIRXINT                 |
|                  | Transmit empty  | TXFFIL    | TXFFIENA   | 1           | SPITXINT                 |

<sup>(1)</sup> In non FIFO mode, SPIRXINT is the same as the SPIINT interrupt in 240x devices.

## 10.1.7 SPI 3-Wire Mode Description

SPI 3-wire mode allows for SPI communication over 3 pins instead of the normal 4 pins.

In master mode, if the TRIWIRE (SPIPRI.0) bit is set, enabling 3-wire SPI mode, SPISIMOx becomes the bi-directional SPIMOMIx (SPI master out, master in) pin, and SPISOMIx is no longer used by the SPI. In slave mode, if the TRIWIRE bit is set, SPISOMIx becomes the bi-directional SPISISOx (SPI slave in, slave out) pin, and SPISIMOX is no longer used by the SPI.

The table below indicates the pin function differences between 3-wire and 4-wire SPI mode for a master and slave SPI.

| 4-wire SPI | 3-wire SPI (Master) | 3-wire SPI(Slave) |  |
|------------|---------------------|-------------------|--|
| SPICLKx    | SPICLKx             | SPICLKx           |  |
| SPISTEx    | SPISTEx             | SPISTEx           |  |
| SPISIMOx   | SPIMOMIx            | Free              |  |
| SPISOMIx   | Free                | SPISISOx          |  |

Table 10-5. 4-wire vs. 3-wire SPI Pin Functions

Because in 3-wire mode, the receive and transmit paths within the SPI are connected, any data transmitted by the SPI module is also received by itself. The application software must take care to perform a dummy read to clear the SPI data register of the additional received data.

The TALK bit (SPICTL.1) plays an important role in 3-wire SPI mode. The bit must be set to transmit data and cleared prior to reading data. In master mode, in order to initiate a read, the application software must write dummy data to the SPI data register (SPIDAT or SPIRXBUF) while the TALK bit is cleared (no data is transmitted out the SPIMOMI pin) before reading from the data register.



Figure 10-8. SPI 3-wire Master Mode

Enhanced SPI Module Overview

Figure 10-9. SPI 3-wire Slave Mode



Table 10-6 indicates how data is received or transmitted in the various SPI modes while the TALK bit is set or cleared.

| Pin Mode   | SPIPRI[TRIWIRE] | SPICTL[TALK] | SPISIMO             | SPISOMI            |
|------------|-----------------|--------------|---------------------|--------------------|
|            |                 | Master Mode  |                     |                    |
| 4-wire     | 0               | Х            | ТХ                  | RX                 |
| 3-pin mode | 1               | 0            | RX                  | Disconnect from SP |
|            |                 | 1            | TX/RX               |                    |
|            |                 | Slave Mode   |                     |                    |
| 4-wire     | 0               | Х            | RX                  | ТХ                 |
| 3-pin mode | 1               | 0            | Disconnect from SPI | RX                 |
|            |                 | 1            |                     | TX/RX              |

#### **SPI 3-Wire Mode Code Examples**

In addition to the normal SPI initialization, to configure the SPI module for 3-wire mode, the TRIWIRE bit (SPIPRI.0) must be set to 1. After initialization, there are several considerations to take into account when transmitting and receiving data in 3-wire master and slave mode. The following examples demonstrate these considerations.

In 3-wire master mode, SPICLKx, SPISTEx, and SPISIMOx pins must be configured as SPI pins (SPISOMIx pin can be configured as non-SPI pin). When the master transmits, it receives the data it transmits (because SPISIMOx and SPISOMIx are connected internally in 3-wire mode). Therefore, the junk data received must be cleared from the receive buffer every time data is transmitted.

Example 10-4. 3-Wire Master Mode Transmit



#### Enhanced SPI Module Overview

www.ti.com

To receive data in 3-wire master mode, the master must clear the TALK (SPICTL.1) bit to 0 to close the transmit path and then transmit dummy data in order to initiate the transfer from the slave. Because the TALK bit is 0, unlike in transmit mode, the master dummy data does not appear on the SPISIMOx pin, and the master does not receive its own dummy data. Instead, the data from the slave is received by the master.

Example 10-5. 3-Wire Master Mode Receive

```
Uint16 rdata;
Uint16 dummy;
SpiaRegs.SPICTL.bit.TALK = 0; // Disable Transmit path
SpiaRegs.SPITXBUF = dummy; // Send dummy to start tx
// NOTE: because TALK = 0, data does not tx onto SPISIMOA pin
while(SpiaRegs.SPISTS.bit.INT_FLAG !=1) {} // Wait until data received
rdata = SpiaRegs.SPIRXBUF; // Master reads data
```

In 3-wire slave mode, SPICLKx, SPISTEx, and SPISOMIx pins must be configured as SPI pins (SPISIMOx pin can be configured as non-SPI pin). Like in master mode, when transmitting, the slave receives the data it transmits and must clear this junk data from its receive buffer.

#### Example 10-6. 3-Wire Slave Mode Transmit

As in 3-wire master mode, the TALK bit must be cleared to 0. Otherwise, the slave receives data normally.

#### Example 10-7. 3-Wire Slave Mode Receive

```
Uint16 rdata;
SpiaRegs.SPICTL.bit.TALK = 0; // Disable Transmit path
while(SpiaRegs.SPISTS.bit.INT_FLAG !=1) {} // Waits until data rx'd
rdata = SpiaRegs.SPIRXBUF; // Slave reads data
```



## 10.2 SPI Registers and Waveforms

This section contains the registers, bit descriptions, and waveforms.

## 10.2.1 SPI Control Registers

The SPI is controlled and accessed through registers in the control register file.

## 10.2.1.1 SPI Configuration Control Register (SPICCR)

SPICCR controls the setup of the SPI for operation.

## Figure 10-10. SPI Configuration Control Register (SPICCR) — Address 7040h

| 7            | 6                 | 5        | 4      | 3         | 2         | 1         | 0         |
|--------------|-------------------|----------|--------|-----------|-----------|-----------|-----------|
| SPI SW Reset | CLOCK<br>POLARITY | Reserved | SPILBK | SPI CHAR3 | SPI CHAR2 | SPI CHAR1 | SPI CHAR0 |
| R/W-0        | R/W-0             | R-0      | R-0    | R/W-0     | R/W-0     | R/W-0     | R/W-0     |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

## Table 10-7. SPI Configuration Control Register (SPICCR) Field Descriptions

| Bit | Field                    | Value | Description                                                                                                                                                                                                                                        |
|-----|--------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SPI SW RESET             |       | SPI software reset. When changing configuration, you should clear this bit before the changes and set this bit before resuming operation.                                                                                                          |
|     |                          | 0     | Initializes the SPI operating flags to the reset condition. Specifically, the RECEIVER OVERRUN Flag bit (SPISTS.7), the SPI INT FLAG bit (SPISTS.6), and the TXBUF FULL Flag bit (SPISTS.5) are cleared. The SPI configuration remains unchanged.  |
|     |                          | 1     | SPI is ready to transmit or receive the next character. When the SPI SW RESET bit is a 0, a character written to the transmitter will not be shifted out when this bit is set. A new character must be written to the serial data register.        |
| 6   | CLOCK<br>POLARITY        |       | Shift Clock Polarity. This bit controls the polarity of the SPICLK signal. CLOCK POLARITY and CLOCK PHASE (SPICTL.3) control four clocking schemes on the SPICLK pin. See Section 10.1.5.3.                                                        |
|     |                          | 0     | Data is output on rising edge and input on falling edge. When no SPI data is sent, SPICLK is at low level. The data input and output edges depend on the value of the CLOCK PHASE bit (SPICTL.3) as follows:                                       |
|     |                          |       | <ul> <li>CLOCK PHASE = 0: Data is output on the rising edge of the SPICLK signal; input data is latched<br/>on the falling edge of the SPICLK signal.</li> </ul>                                                                                   |
|     |                          |       | <ul> <li>CLOCK PHASE = 1: Data is output one half-cycle before the first rising edge of the SPICLK<br/>signal and on subsequent falling edges of the SPICLK signal; input data is latched on the rising<br/>edge of the SPICLK signal.</li> </ul>  |
|     |                          | 1     | Data is output on falling edge and input on rising edge. When no SPI data is sent, SPICLK is at high level. The data input and output edges depend on the value of the CLOCK PHASE bit (SPICTL.3) as follows:                                      |
|     |                          |       | <ul> <li>CLOCK PHASE = 0: Data is output on the falling edge of the SPICLK signal; input data is<br/>latched on the rising edge of the SPICLK signal.</li> </ul>                                                                                   |
|     |                          |       | <ul> <li>CLOCK PHASE = 1: Data is output one half-cycle before the first falling edge of the SPICLK<br/>signal and on subsequent rising edges of the SPICLK signal; input data is latched on the falling<br/>edge of the SPICLK signal.</li> </ul> |
| 5   | Reserved                 |       | Reads return zero; writes have no effect.                                                                                                                                                                                                          |
| 4   | SPILBK                   |       | SPI loopback. Loop back mode allows module validation during device testing. This mode is valid only in master mode of the SPI.                                                                                                                    |
|     |                          | 0     | SPI loop back mode disabled – default value after reset                                                                                                                                                                                            |
|     |                          | 1     | SPI loop back mode enabled, SIMO/SOMI lines are connected internally. Used for module self tests.                                                                                                                                                  |
| 3-0 | SPI CHAR3 -<br>SPI CHAR0 |       | Character Length Control Bits 3-0. These four bits determine the number of bits to be shifted in or out as a single character during one shift sequence. Table 10-8 lists the character length selected by the bit values.                         |

706 Serial Peripheral Interface (SPI)

SPRUHE5B-November 2012-Revised April 2013

Submit Documentation Feedback

| SPI | Registers | and | Waveforms |
|-----|-----------|-----|-----------|
|-----|-----------|-----|-----------|

| SPI CHAR3 | SPI CHAR2 | SPI CHAR1 | SPI CHAR0 | Character Length |
|-----------|-----------|-----------|-----------|------------------|
| 0         | 0         | 0         | 0         | 1                |
| 0         | 0         | 0         | 1         | 2                |
| 0         | 0         | 1         | 0         | 3                |
| 0         | 0         | 1         | 1         | 4                |
| 0         | 1         | 0         | 0         | 5                |
| 0         | 1         | 0         | 1         | 6                |
| 0         | 1         | 1         | 0         | 7                |
| 0         | 1         | 1         | 1         | 8                |
| 1         | 0         | 0         | 0         | 9                |
| 1         | 0         | 0         | 1         | 10               |
| 1         | 0         | 1         | 0         | 11               |
| 1         | 0         | 1         | 1         | 12               |
| 1         | 1         | 0         | 0         | 13               |
| 1         | 1         | 0         | 1         | 14               |
| 1         | 1         | 1         | 0         | 15               |
| 1         | 1         | 1         | 1         | 16               |

Table 10-8. Character Length Control Bit Values

## 10.2.1.2 SPI Operation Control Register (SPICTL)

SPICTL controls data transmission, the SPI's ability to generate interrupts, the SPICLK phase, and the operational mode (slave or master).

## Figure 10-11. SPI Operation Control Register (SPICTL) — Address 7041h

| 7 | 6        | 5 | 4                  | 3              | 2                | 1     | 0           |
|---|----------|---|--------------------|----------------|------------------|-------|-------------|
|   | Reserved |   | OVERRUN INT<br>ENA | CLOCK<br>PHASE | MASTER/<br>SLAVE | TALK  | SPI INT ENA |
|   | R-0      |   | R/W-0              | R/W-0          | R/W-0            | R/W-0 | R/W-0       |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

## Table 10-9. SPI Operation Control Register (SPICTL) Field Descriptions

| Bit | Field             | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|-----|-------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7-5 | Reserved          |       | Reads return zero; writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| 4   | Overrun INT ENA   |       | Overrun Interrupt Enable. Setting this bit causes an interrupt to be generated when the RECEIVER OVERRUN Flag bit (SPISTS.7) is set by hardware. Interrupts generated by the RECEIVER OVERRUN Flag bit and the SPI INT FLAG bit (SPISTS.6) share the same interrupt vector.                                                                                                                                                |  |  |  |
|     |                   | 0     | able RECEIVER OVERRUN Flag bit (SPISTS.7) interrupts                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|     |                   | 1     | Enable RECEIVER OVERRUN Flag bit (SPISTS.7) interrupts                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| 3   | CLOCK PHASE       |       | SPI Clock Phase Select. This bit controls the phase of the SPICLK signal.<br>CLOCK PHASE and CLOCK POLARITY (SPICCR.6) make four different clocking schemes<br>possible (see Figure 10-4). When operating with CLOCK PHASE high, the SPI (master or slave)<br>makes the first bit of data available after SPIDAT is written and before the first edge of the SPICLK<br>signal, regardless of which SPI mode is being used. |  |  |  |
|     |                   | 0     | Normal SPI clocking scheme, depending on the CLOCK POLARITY bit (SPICCR.6)                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|     |                   | 1     | SPICLK signal delayed by one half-cycle; polarity determined by the CLOCK POLARITY bit                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| 2   | MASTER /<br>SLAVE |       | SPI Network Mode Control. This bit determines whether the SPI is a network master or slave.<br>During reset initialization, the SPI is automatically configured as a network slave.                                                                                                                                                                                                                                        |  |  |  |
|     |                   | 0     | SPI configured as a slave.                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|     |                   | 1     | SPI configured as a master.                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |



www.ti.com



## Table 10-9. SPI Operation Control Register (SPICTL) Field Descriptions (continued)

| Bit | Field       | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | TALK        |       | Master/Slave Transmit Enable. The TALK bit can disable data transmission (master or slave) by placing the serial data output in the high-impedance state. If this bit is disabled during a transmission, the transmit shift register continues to operate until the previous character is shifted out. When the TALK bit is disabled, the SPI is still able to receive characters and update the status flags. TALK is cleared (disabled) by a system reset. |
|     |             | 0     | Disables transmission:                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |             |       | <ul> <li>Slave mode operation: If not previously configured as a general-purpose I/O pin, the SPISOMI pin will be put in the high-impedance state.</li> </ul>                                                                                                                                                                                                                                                                                                |
|     |             |       | <ul> <li>Master mode operation: If not previously configured as a general-purpose I/O pin, the SPISIMO<br/>pin will be put in the high-impedance state.</li> </ul>                                                                                                                                                                                                                                                                                           |
|     |             | 1     | Enables transmission For the 4-pin option, ensure to enable the receiver's SPISTE input pin.                                                                                                                                                                                                                                                                                                                                                                 |
| 0   | SPI INT ENA |       | SPI Interrupt Enable. This bit controls the SPI's ability to generate a transmit/receive interrupt. The SPI INT FLAG bit (SPISTS.6) is unaffected by this bit.                                                                                                                                                                                                                                                                                               |
|     |             | 0     | Disables interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |             | 1     | Enables interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                            |

## 10.2.1.3 SPI Status Register (SPIST)

#### Figure 10-12. SPI Status Register (SPIST) — Address 7042h

| 7                                              | 6                                  | 5                                  | 4                      | 0 |
|------------------------------------------------|------------------------------------|------------------------------------|------------------------|---|
| RECEIVER<br>OVERRUN<br>FLAG <sup>(1) (2)</sup> | SPI INT<br>FLAG <sup>(1) (2)</sup> | TX BUF FULL<br>FLAG <sup>(2)</sup> | Reserved               |   |
| R/C-0                                          | R/C-0                              | R/C-0                              | R-0                    |   |
|                                                |                                    | Description of the second second   | - here a flam was a fl |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

<sup>(1)</sup> The RECEIVER OVERRUN FLAG bit and the SPI INT FLAG bit share the same interrupt vector.

<sup>(2)</sup> Writing a 0 to bits 5, 6, and 7 has no effect.

## Table 10-10. SPI Status Register (SPIST) Field Descriptions

| Bit | Field                    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|--------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RECEIVER<br>OVERRUN FLAG |       | SPI Receiver Overrun Flag. This bit is a read/clear-only flag. The SPI hardware sets this bit when a receive or transmit operation completes before the previous character has been read from the buffer. The bit indicates that the last received character has been overwritten and therefore lost (when the SPIRXBUF was overwritten by the SPI module before the previous character was read by the user application). The SPI requests one interrupt sequence each time this bit is set if the OVERRUN INT ENA bit (SPICTL.4) is set high. The bit is cleared in one of three ways:                                                                                                         |
|     |                          |       | Writing a 1 to this bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |                          |       | Writing a 0 to SPI SW RESET (SPICCR.7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |                          |       | <ul> <li>Resetting the system</li> <li>If the OVERRUN INT ENA bit (SPICTL.4) is set, the SPI requests only one interrupt upon the first occurrence of setting the RECEIVER OVERRUN Flag bit. Subsequent overruns will not request additional interrupts if this flag bit is already set. This means that in order to allow new overrun interrupt requests the user must clear this flag bit by writing a 1 to SPISTS.7 each time an overrun condition occurs. In other words, if the RECEIVER OVERRUN Flag bit is left set (not cleared) by the interrupt service routine, another overrun interrupt will not be immediately re-entered when the interrupt service routine is exited.</li> </ul> |
|     |                          | 0     | Writing a 0 has no effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |                          | 1     | Clears this bit. The RECEIVER OVERRUN Flag bit should be cleared during the interrupt service routine because the RECEIVER OVERRUN Flag bit and SPI INT FLAG bit (SPISTS.6) share the same interrupt vector. This will alleviate any possible doubt as to the source of the interrupt when the next byte is received.                                                                                                                                                                                                                                                                                                                                                                            |



4-0

Reserved

|     | TUDIO               | , 10 10. |                                                                                                                                                                                                                                                                                                                                                                         |
|-----|---------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Field               | Value    | Description                                                                                                                                                                                                                                                                                                                                                             |
| 6   | SPI INT FLAG        |          | SPI Interrupt Flag. SPI INT FLAG is a read-only flag. The SPI hardware sets this bit to indicate that it has completed sending or receiving the last bit and is ready to be serviced. The received character is placed in the receiver buffer at the same time this bit is set. This flag causes an interrupt to be requested if the SPI INT ENA bit (SPICTL.0) is set. |
|     |                     | 0        | Writing a 0 has no effect                                                                                                                                                                                                                                                                                                                                               |
|     |                     | 1        | This bit is cleared in one of three ways:                                                                                                                                                                                                                                                                                                                               |
|     |                     |          | Reading SPIRXBUF                                                                                                                                                                                                                                                                                                                                                        |
|     |                     |          | Writing a 0 to SPI SW RESET (SPICCR.7)                                                                                                                                                                                                                                                                                                                                  |
|     |                     |          | Resetting the system                                                                                                                                                                                                                                                                                                                                                    |
| 5   | TX BUF FULL<br>FLAG |          | SPI Transmit Buffer Full Flag. This read-only bit gets set to 1 when a character is written to the SPI Transmit buffer SPITXBUF. It is cleared when the character is automatically loaded into SPIDAT when the shifting out of a previous character is complete.                                                                                                        |
|     |                     | 0        | Writing a 0 has no effect                                                                                                                                                                                                                                                                                                                                               |
|     |                     | 1        | This bit is cleared at reset.                                                                                                                                                                                                                                                                                                                                           |

## Table 10-10. SPI Status Register (SPIST) Field Descriptions (continued)

## 10.2.1.4 SPI Baud Rate Register (SPIBRR)

0

SPIBRR contains the bits used for baud-rate selection.

## Figure 10-13. SPI Baud Rate Register (SPIBRR) — Address 7044h

| 7             | 6                                                               | 5              | 4              | 3              | 2              | 1              | 0              |  |  |  |
|---------------|-----------------------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|--|--|--|
| Reserved      | SPI BIT RATE 6                                                  | SPI BIT RATE 5 | SPI BIT RATE 4 | SPI BIT RATE 3 | SPI BIT RATE 2 | SPI BIT RATE 1 | SPI BIT RATE 0 |  |  |  |
| R-0           | RW-0                                                            | RW-0           | RW-0           | RW-0           | RW-0           | RW-0           | RW-0           |  |  |  |
| LEGEND: R/W : | LEGEND: R/W = Read/Write; R = Read only; -n = value after reset |                |                |                |                |                |                |  |  |  |

Reads return zero; writes have no effect.

#### Table 10-11. Field Descriptions

| Bit | Field                             | Value | Description                                                                                                                                                                                                                                                                                                            |  |
|-----|-----------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7   | Reserved                          |       | Reads return zero; writes have no effect.                                                                                                                                                                                                                                                                              |  |
| 6-0 | SPI BIT RATE 6-<br>SPI BIT RATE 0 |       | SPI Bit Rate (Baud) Control. These bits determine the bit transfer rate if the SPI is the network<br>master. There are 125 data-transfer rates (each a function of the CPU clock, LSPCLK) that car<br>selected. One data bit is shifted per SPICLK cycle. (SPICLK is the baud rate clock output on the<br>SPICLK pin.) |  |
|     |                                   |       | If the SPI is a network slave, the module receives a clock on the SPICLK pin from the network master; therefore, these bits have no effect on the SPICLK signal. The frequency of the input clock from the master should not exceed the slave SPI's SPICLK signal divided by 4.                                        |  |
|     |                                   |       | In master mode, the SPI clock is generated by the SPI and is output on the SPICLK pin. The SPI baud rates are determined by the following formula:                                                                                                                                                                     |  |
|     |                                   |       | For SPIBRR = 3 to 127:<br>SPI Baud Rate = $\frac{\text{LSPCLK}}{(\text{SPIBRR} + 1)}$                                                                                                                                                                                                                                  |  |
|     |                                   |       | For SPIBRR = 0, 1, or 2: SPI Baud Rate = $\frac{\text{LSPCLK}}{4}$                                                                                                                                                                                                                                                     |  |
|     |                                   |       | where: LSPCLK = Function of CPU clock frequency X low-speed peripheral clock of the device                                                                                                                                                                                                                             |  |
|     |                                   |       | SPIBRR = Contents of the SPIBRR in the master SPI device                                                                                                                                                                                                                                                               |  |

#### 10.2.1.5 SPI Emulation Buffer Register (SPIRXEMU)

SPIRXEMU contains the received data. Reading SPIRXEMU does not clear the SPI INT FLAG bit (SPISTS.6). This is not a real register but a dummy address from which the contents of SPIRXBUF can be read by the emulator without clearing the SPI INT FLAG.

## Figure 10-14. SPI Emulation Buffer Register (SPIRXEMU) — Address 7046h

| 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          |
|------------|------------|------------|------------|------------|------------|------------|------------|
| ERXB15     | ERXB14     | ERXB13     | ERXB12     | ERXB11     | ERXB10     | ERXB9      | ERXB8      |
| R-0        |
|            |            |            |            |            |            |            |            |
| 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
| 7<br>ERXB7 | 6<br>ERXB6 | 5<br>ERXB5 | 4<br>ERXB4 | 3<br>ERXB3 | 2<br>ERXB2 | 1<br>ERXB1 | 0<br>ERXB0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 10-12. SPI Emulation Buffer Register (SPIRXEMU) Field Descriptions

| Bit  | Field         | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|---------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | ERXB15- ERXB0 |       | Emulation Buffer Received Data. SPIRXEMU functions almost identically to SPIRXBUF, except that reading SPIRXEMU does not clear the SPI INT FLAG bit (SPISTS.6). Once the SPIDAT has received the complete character, the character is transferred to SPIRXEMU and SPIRXBUF, where it can be read. At the same time, SPI INT FLAG is set.                                                                                                                                                                                                                                                           |
|      |               |       | This mirror register was created to support emulation. Reading SPIRXBUF clears the SPI INT FLAG bit (SPISTS.6). In the normal operation of the emulator, the control registers are read to continually update the contents of these registers on the display screen. SPIRXEMU was created so that the emulator can read this register and properly update the contents on the display screen. Reading SPIRXEMU does not clear the SPI INT FLAG bit, but reading SPIRXBUF clears this flag. In other words, SPIRXEMU enables the emulator to emulate the true operation of the SPI more accurately. |
|      |               |       | It is recommended that you view SPIRXEMU in the normal emulator run mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

## 10.2.1.6 SPI Serial Receive Buffer Register (SPIRXBUF)

SPIRXBUF contains the received data. Reading SPIRXBUF clears the SPI INT FLAG bit (SPISTS.6).

## Figure 10-15. SPI Serial Receive Buffer Register (SPIRXBUF) — Address 7047h

| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    |
|-------|-------|-------|-------|-------|-------|------|------|
| RXB15 | RXB14 | RXB13 | RXB12 | RXB11 | RXB10 | RXB9 | RXB8 |
| R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0  | R-0  |
| 7     | 6     | 5     | 4     | 3     | 2     | 1    | 0    |
| RXB7  | RXB6  | RXB5  | RXB4  | RXB3  | RXB2  | RXB1 | RXB0 |
| R-0   |       |       |       |       |       |      | R-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 10-13. SPI Serial Receive Buffer Register (SPIRXBUF) Field Descriptions

| Bit  | Field        | Value | Description                                                                                                                                                                                                                                                                                               |
|------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | RXB15 - RXB0 |       | Received Data. Once SPIDAT has received the complete character, the character is transferred to SPIRXBUF, where it can be read. At the same time, the SPI INT FLAG bit (SPISTS.6) is set. Since data is shifted into the SPI's most significant bit first, it is stored right-justified in this register. |



## 10.2.1.7 SPI Serial Transmit Buffer Register (SPITXBUF)

SPITXBUF stores the next character to be transmitted. Writing to this register sets the TX BUF FULL Flag bit (SPISTS.5). When transmission of the current character is complete, the contents of this register are automatically loaded in SPIDAT and the TX BUF FULL Flag is cleared. If no transmission is currently active, data written to this register falls through into the SPIDAT register and the TX BUF FULL Flag is not set.

In master mode, if no transmission is currently active, writing to this register initiates a transmission in the same manner that writing to SPIDAT does.

| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    |
|-------|-------|-------|-------|-------|-------|------|------|
| TXB15 | TXB14 | TXB13 | TXB12 | TXB11 | TXB10 | TXB9 | TXB8 |
| R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0  | R-0  |
| 7     | 6     | 5     | 4     | 3     | 2     | 1    | 0    |
| TXB7  | TXB6  | TXB5  | TXB4  | TXB3  | TXB2  | TXB1 | TXB0 |
| R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0  | R-0  |

#### Figure 10-16. SPI Serial Transmit Buffer Register (SPITXBUF) — Address 7048h

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 10-14. SPI Serial Transmit Buffer Register (SPITXBUF) Field Descriptions

| Bit  | Field        | Value | Description                                                                                                                                                                                                                                                                                                                                    |
|------|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | TXB15 – TXB0 |       | Transmit Data Buffer. This is where the next character to be transmitted is stored. When the transmission of the current character has completed, if the TX BUF FULL Flag bit is set, the contents of this register is automatically transferred to SPIDAT, and the TX BUF FULL Flag is cleared.<br>Writes to SPITXBUF must be left-justified. |

#### 10.2.1.8 SPI Serial Data Register (SPIDAT)

SPIDAT is the transmit/receive shift register. Data written to SPIDAT is shifted out (MSB) on subsequent SPICLK cycles. For every bit (MSB) shifted out of the SPI, a bit is shifted into the LSB end of the shift register.

| 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     |  |  |  |  |
|--------|--------|--------|--------|--------|--------|-------|-------|--|--|--|--|
| SDAT15 | SDAT14 | SDAT13 | SDAT12 | SDAT11 | SDAT10 | SDAT9 | SDAT8 |  |  |  |  |
| R-0    | R-0    | R-0    | R-0    | R-0    | R-0    | R-0   | R-0   |  |  |  |  |
| 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |  |  |  |  |
| SDAT7  | SDAT6  | SDAT5  | SDAT4  | SDAT3  | SDAT2  | SDAT1 | SDAT0 |  |  |  |  |
| R-0    | R-0    | R-0    | R-0    | R-0    | R-0    | R-0   | R-0   |  |  |  |  |

#### Figure 10-17. SPI Serial Data Register (SPIDAT) — Address 7049h

| Table 10-15. SPI Ser | ial Data Register | (SPIDAT) | ) Field Descriptions |
|----------------------|-------------------|----------|----------------------|
|----------------------|-------------------|----------|----------------------|

| Bit  | Field         | Value | Description                                                                                                                                                                                                                                                                              |
|------|---------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | 15-0 SDAT15 - |       | Serial data. Writing to the SPIDAT performs two functions:                                                                                                                                                                                                                               |
|      | SDAT0         |       | <ul> <li>It provides data to be output on the serial output pin if the TALK bit (SPICTL.1) is set.</li> </ul>                                                                                                                                                                            |
|      |               |       | <ul> <li>When the SPI is operating as a master, a data transfer is initiated. When initiating a transfer, see<br/>the CLOCK POLARITY bit (SPICCR.6) described in Section 10.2.1.1 and the CLOCK PHASE bit<br/>(SPICTL.3) described in Section 10.2.1.2, for the requirements.</li> </ul> |
|      |               |       | In master mode, writing dummy data to SPIDAT initiates a receiver sequence. Since the data is not hardware-justified for characters shorter than sixteen bits, transmit data must be written in left-justified form, and received data read in right-justified form.                     |

## 10.2.1.9 SPI FIFO Transmit, Receive, and Control Registers

|              |             | • • • • • • • • • |         |         | - <u>g</u> |         |         |
|--------------|-------------|-------------------|---------|---------|------------|---------|---------|
| 15           | 14          | 13                | 12      | 11      | 10         | 9       | 8       |
| SPIRST       | SPIFFENA    | TXFIFO            | TXFFST4 | TXFFST3 | TXFFST2    | TXFFST1 | TXFFST0 |
| R/W-1        | R/W-0       | R/W-1             | R-0     | R-0     | R-0        | R-0     | R-0     |
| 7            | 6           | 5                 | 4       | 3       | 2          | 1       | 0       |
| TXFFINT Flag | TXFFINT CLR | TXFFIENA          | TXFFIL4 | TXFFIL3 | TXFFIL2    | TXFFIL1 | TXFFIL0 |
| R/W-0        | W-0         | R/W-0             | R/W-0   | R/W-0   | R/W-0      | R/W-0   | R/W-0   |
|              |             |                   |         |         |            |         |         |

#### Figure 10-18. SPI FIFO Transmit (SPIFFTX) Register - Address 704Ah

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 10-16. SPI FIFO Transmit (SPIFFTX) Register Field Descriptions

| Bit  | Field        | Value | Description                                                                                                                                                                              |
|------|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | SPIRST       |       | SPI reset                                                                                                                                                                                |
|      |              | 0     | Write 0 to reset the SPI transmit and receive channels. The SPI FIFO register configuration bits will be left as is.                                                                     |
|      |              | 1     | SPI FIFO can resume transmit or receive. No effect to the SPI registers bits.                                                                                                            |
| 14   | SPIFFENA     |       | SPI FIFO enhancements enable                                                                                                                                                             |
|      |              | 0     | SPI FIFO enhancements are disabled                                                                                                                                                       |
|      |              | 1     | SPI FIFO enhancements are enabled                                                                                                                                                        |
| 13   | TXFIFO Reset |       | Transmit FIFO reset                                                                                                                                                                      |
|      |              | 0     | Write 0 to reset the FIFO pointer to zero, and hold in reset.                                                                                                                            |
|      |              | 1     | Re-enable Transmit FIFO operation                                                                                                                                                        |
| 12-8 | TXFFST4-0    |       | Transmit FIFO status                                                                                                                                                                     |
|      |              | 00000 | Transmit FIFO is empty.                                                                                                                                                                  |
|      |              | 00001 | Transmit FIFO has 1 word.                                                                                                                                                                |
|      |              | 00010 | Transmit FIFO has 2 words.                                                                                                                                                               |
|      |              | 00011 | Transmit FIFO has 3 words.                                                                                                                                                               |
|      |              | 00100 | Transmit FIFO has 4 words, which is the maximum.                                                                                                                                         |
| 7    | TXFFINT      |       | TXFIFO interrupt                                                                                                                                                                         |
|      |              | 0     | TXFIFO interrupt has not occurred, This is a read-only bit.                                                                                                                              |
|      |              | 1     | TXFIFO interrupt has occurred, This is a read-only bit.                                                                                                                                  |
| 6    | TXFFINT CLR  |       | TXFIFO clear                                                                                                                                                                             |
|      |              | 0     | Write 0 has no effect on TXFIFINT flag bit, Bit reads back a zero.                                                                                                                       |
|      |              | 1     | Write 1 to clear TXFFINT flag in bit 7.                                                                                                                                                  |
| 5    | TXFFIENA     |       | TX FIFO interrupt enable                                                                                                                                                                 |
|      |              | 0     | TX FIFO interrupt based on TXFFIVL match (less than or equal to) will be disabled .                                                                                                      |
|      |              | 1     | TX FIFO interrupt based on TXFFIVL match (less than or equal to) will be enabled.                                                                                                        |
| 4-0  | TXFFIL4-0    |       | TXFFIL4-0 transmit FIFO interrupt level bits. Transmit FIFO will generate interrupt when the FIFO status bits (TXFFST4-0) and FIFO level bits (TXFFIL4-0) match (less than or equal to). |
|      |              | 00000 | Default value is 0x00000.                                                                                                                                                                |

## Figure 10-19. SPI FIFO Receive (SPIFFRX) Register - Address 704Bh

| 15                  | 14                                                           | 13                  | 12      | 11      | 10      | 9       | 8       |  |  |  |
|---------------------|--------------------------------------------------------------|---------------------|---------|---------|---------|---------|---------|--|--|--|
| <b>RXFFOVF</b> Flag | RXFFOVF CLR                                                  | <b>RXFIFO Reset</b> | RXFFST4 | RXFFST3 | RXFFST2 | RXFFST1 | RXFFST0 |  |  |  |
| R-0                 | W-0                                                          | R/W-1               | R-0     | R-0     | R-0     | R-0     | R-0     |  |  |  |
| 7                   | 6                                                            | 5                   | 4       | 3       | 2       | 1       | 0       |  |  |  |
| RXFFINT Flag        | RXFFINT CLR                                                  | RXFFIENA            | RXFFIL4 | RXFFIL3 | RXFFIL2 | RXFFIL1 | RXFFIL0 |  |  |  |
| R-0                 | W-0                                                          | R/W-0               | R/W-1   | R/W-1   | R/W-1   | R/W-1   | R/W-1   |  |  |  |
|                     | LECEND: DAM DeadAN/rite: D. Dead only n. victure offer react |                     |         |         |         |         |         |  |  |  |



| Bit  | Field        | Value | Description                                                                                                                                                                                                                                                                                    |
|------|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | RXFFOVF      |       | Receive FIFO overflow flag                                                                                                                                                                                                                                                                     |
|      |              | 0     | Receive FIFO has not overflowed. This is a read-only bit.                                                                                                                                                                                                                                      |
|      |              | 1     | Receive FIFO has overflowed, read-only bit. More than 16 words have been received in to the FIFO, and the first received word is lost.                                                                                                                                                         |
| 14   | RXFFOVF CLR  |       | Receive FIFO overflow clear                                                                                                                                                                                                                                                                    |
|      |              | 0     | Write 0 does not affect RXFFOVF flag bit, Bit reads back a zero                                                                                                                                                                                                                                |
|      |              | 1     | Write 1 to clear RXFFOVF flag in bit 15                                                                                                                                                                                                                                                        |
| 13   | RXFIFO Reset |       | Receive FIFO reset                                                                                                                                                                                                                                                                             |
|      |              | 0     | Write 0 to reset the FIFO pointer to zero, and hold in reset.                                                                                                                                                                                                                                  |
|      |              | 1     | Re-enable receive FIFO operation                                                                                                                                                                                                                                                               |
| 12-8 | RXFFST4-0    |       | Receive FIFO Status                                                                                                                                                                                                                                                                            |
|      |              | 00000 | Receive FIFO is empty.                                                                                                                                                                                                                                                                         |
|      |              | 00001 | Receive FIFO has 1 word.                                                                                                                                                                                                                                                                       |
|      |              | 00010 | Receive FIFO has 2 words.                                                                                                                                                                                                                                                                      |
|      |              | 00011 | Receive FIFO has 3 words.                                                                                                                                                                                                                                                                      |
|      |              | 00100 | Receive FIFO has 4 words. Receive FIFO has a maximum of 4 words.                                                                                                                                                                                                                               |
| 7    | RXFFINT      |       | Receive FIFO interrupt                                                                                                                                                                                                                                                                         |
|      |              | 0     | RXFIFO interrupt has not occurred. This is a read-only bit.                                                                                                                                                                                                                                    |
|      |              | 1     | RXFIFO interrupt has occurred. This is a read-only bit.                                                                                                                                                                                                                                        |
| 6    | RXFFINT CLR  |       | Receive FIFO interrupt clear                                                                                                                                                                                                                                                                   |
|      |              | 0     | Write 0 has no effect on RXFIFINT flag bit, Bit reads back a zero.                                                                                                                                                                                                                             |
|      |              | 1     | Write 1 to clear RXFFINT flag in bit 7.                                                                                                                                                                                                                                                        |
| 5    | RXFFIENA     |       | RX FIFO interrupt enable                                                                                                                                                                                                                                                                       |
|      |              | 0     | RX FIFO interrupt based on RXFFIL match (greater than or equal to) will be disabled.                                                                                                                                                                                                           |
|      |              | 1     | RX FIFO interrupt based on RXFFIL match (greater than or equal to) will be enabled.                                                                                                                                                                                                            |
| 4-0  | RXFFIL4-0    |       | Receive FIFO interrupt level bits                                                                                                                                                                                                                                                              |
|      |              | 11111 | Receive FIFO generates an interrupt when the FIFO status bits (RXFFST4–0) are greater than or equal to the FIFO level bits (RXFFIL4–0). The default value of these bits after reset is 11111. This avoids frequent interrupts after reset, as the receive FIFO will be empty most of the time. |

## Table 10-17. SPI FIFO Receive (SPIFFRX) Register Field Descriptions

## Figure 10-20. SPI FIFO Control (SPIFFCT) Register - Address 704Ch

| 15       |          |          |          |          |          |          | 8        |  |  |  |
|----------|----------|----------|----------|----------|----------|----------|----------|--|--|--|
|          | Reserved |          |          |          |          |          |          |  |  |  |
| R-0      |          |          |          |          |          |          |          |  |  |  |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |  |  |  |
| FFTXDLY7 | FFTXDLY6 | FFTXDLY5 | FFTXDLY4 | FFTXDLY3 | FFTXDLY2 | FFTXDLY1 | FFTXDLY0 |  |  |  |
| R/W-0    |  |  |  |

| Bit  | Field      | Value | Description                                                                                                                                                                                                                                                                                                                 |
|------|------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved   |       | Reads return zero; writes have no effect.                                                                                                                                                                                                                                                                                   |
| 7-0  | FFTXDLY7-0 |       | FIFO transmit delay bits                                                                                                                                                                                                                                                                                                    |
|      |            | 0     | These bits define the delay between every transfer from FIFO transmit buffer to transmit shift register. The delay is defined in number SPI serial clock cycles. The 8-bit register could define a minimum delay of 0 serial clock cycles and a maximum of 255 serial clock cycles.                                         |
|      |            | 1     | In FIFO mode, the buffer (TXBUF) between the shift register and the FIFO should be filled only after the shift register has completed shifting of the last bit. This is required to pass on the delay between transfers to the data stream. In the FIFO mode TXBUF should not be treated as one additional level of buffer. |

## 10.2.1.10 SPI Priority Control Register (SPIPRI)

| 15   |       |                  |                  |      |       |        | 8       |
|------|-------|------------------|------------------|------|-------|--------|---------|
|      |       |                  | Reserv           | ved  |       |        |         |
| R-0  |       |                  |                  |      |       |        |         |
| 7    | 6     | 5                | 4                | 3    | 2     | 1      | 0       |
| Rese | erved | SPI SUSP<br>SOFT | SPI SUSP<br>FREE | Rese | erved | STEINV | TRIWIRE |
| R-0  |       | R/W-0            | R/W-0            | R    | -0    | R/W-0  | R/W-0   |

## Figure 10-21. SPI Priority Control Register (SPIPRI) — Address 704Fh

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

## Table 10-19. SPI Priority Control Register (SPIPRI) Field Descriptions

| Bit  | Field                          | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-6 | Reserved                       |       | Reads return zero; writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5-4  | SPI SUSP SOFT<br>SPI SUSP FREE |       | These bits determine what occurs when an emulation suspend occurs (for example, when the debugger hits a breakpoint). The peripheral can continue whatever it is doing (free-run mode) or, if in stop mode, it can either stop immediately or stop when the current operation (the current receive/transmit sequence) is complete.                                                                                                                                                                                   |
|      |                                | 00    | Transmission stops after midway in the bit stream while TSUSPEND is asserted. Once TSUSPEND is deasserted without a system reset, the remainder of the bits pending in the DATBUF are shifted. Example: If SPIDAT has shifted 3 out of 8 bits, the communication freezes right there. However, if TSUSPEND is later deasserted without resetting the SPI, SPI starts transmitting from where it had stopped (fourth bit in this case) and will transmit 8 bits from that point. The SCI module operates differently. |
|      |                                | 10    | If the emulation suspend occurs before the start of a transmission, (that is, before the first SPICLK pulse) then the transmission will not occur. If the emulation suspend occurs after the start of a transmission, then the data will be shifted out to completion. When the start of transmission occurs is dependent on the baud rate used.                                                                                                                                                                     |
|      |                                |       | <i>Standard SPI mode:</i> Stop after transmitting the words in the shift register and buffer. That is, after TXBUF and SPIDAT are empty.                                                                                                                                                                                                                                                                                                                                                                             |
|      |                                |       | <i>In FIFO mode:</i> Stop after transmitting the words in the shift register and buffer. That is, after TX FIFO and SPIDAT are empty.                                                                                                                                                                                                                                                                                                                                                                                |
|      |                                | x 1   | Free run, continue SPI operation regardless of suspend or when the suspend occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3-2  | Reserved                       |       | Reads return zero; writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1    | STEINV                         |       | SPISTE inversion bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|      |                                |       | On devices with 2 SPI modules, inverting the SPISTE signal on one of the modules allows the device to receive left and right- channel digital audio data.                                                                                                                                                                                                                                                                                                                                                            |
|      |                                | 0     | SPISTE is active low (normal)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      |                                | 1     | SPISTE is active high (inverted)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0    | TRIWIRE                        |       | SPI 3-wire mode enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                                | 0     | Normal 4-wire SPI mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                                | 1     | 3-wire SPI mode enabled. The unused pin becomes a GPIO pin. In master mode, the SPISIMO pin becomes the SPIMOMI (master receive and transmit) pin and SPISOMI is free for non-SPI use. In slave mode, the SIISOMI pin becomes the SPISISO (slave receive and transmit) pin and SPISIMO is free for non-SPI use.                                                                                                                                                                                                      |

## 10.2.2 SPI Example Waveforms



Figure 10-22. CLOCK POLARITY = 0, CLOCK PHASE = 0 (All data transitions are during the rising edge, non-delayed clock. Inactive level is low.)





Figure 10-23. CLOCK POLARITY = 0, CLOCK PHASE = 1 (All data transitions are during the rising edge, but delayed by half clock cycle. Inactive level is low.)

Figure 10-24. CLOCK POLARITY = 1, CLOCK PHASE = 0 (All data transitions are during the falling edge. Inactive level is high.)







Figure 10-26. SPISTE Behavior in Master Mode (Master lowers SPISTE during the entire 16 bits of transmission.)





# Figure 10-27. SPISTE Behavior in Slave Mode (Slave's SPISTE is lowered during the entire 16 bits of transmission.)





Page

# Serial Communications Interface (SCI)

The serial communications interface (SCI) is a two-wire asynchronous serial port, commonly known as a UART. The SCI modules support digital communications between the CPU and other asynchronous peripherals that use the standard non-return-to-zero (NRZ) format. The SCI receiver and transmitter each have a 4-level deep FIFO for reducing servicing overhead, and each has its own separate enable and interrupt bits. Both can be operated independently for half-duplex communication, or simultaneously for full-duplex communication.

To specify data integrity, the SCI checks received data for break detection, parity, overrun, and framing errors. The bit rate is programmable to different speeds through a 16-bit baud-select register.

#### Topic

| 11.1 | Enhanced SCI Module Overview | 719 |
|------|------------------------------|-----|
| 11.2 | SCI Registers                | 732 |



## 11.1 Enhanced SCI Module Overview

The SCI interfaces are shown in Figure 11-1.



Figure 11-1. SCI CPU Interface

Features of the SCI module include:

- Two external pins:
  - SCITXD: SCI transmit-output pin
  - SCIRXD: SCI receive-input pin

Both pins can be used as GPIO if not used for SCI.

- Baud rate programmable to 64K different rates
- Data-word format
  - One start bit
  - Data-word length programmable from one to eight bits
  - Optional even/odd/no parity bit
  - One or two stop bits
- · Four error-detection flags: parity, overrun, framing, and break detection
- Two wake-up multiprocessor modes: idle-line and address bit
- Half- or full-duplex operation
- Double-buffered receive and transmit functions
- Transmitter and receiver operations can be accomplished through interrupt- driven or polled algorithms with status flags.
- Separate enable bits for transmitter and receiver interrupts (except BRKDT)
- NRZ (non-return-to-zero) format
- 13 SCI module control registers located in the control register frame beginning at address 7050h
   All registers in this module are 8-bit registers that are connected to Peripheral Frame 2. When a register is accessed, the register data is in the lower byte (7–0), and the upper byte (15–8) is read as zeros. Writing to the upper byte has no effect.

#### **Enhanced features:**

Enhanced SCI Module Overview

- Auto-baud-detect hardware logic
- 4-level transmit/receive FIFO

Figure 11-2 shows the SCI module block diagram. The SCI port operation is configured and controlled by the registers listed in Table 11-5 and Table 11-6.





## 11.1.1 Architecture

The major elements used in full-duplex operation are shown in Figure 11-2 and include:

- A transmitter (TX) and its major registers (upper half of Figure 11-2)
  - SCITXBUF transmitter data buffer register. Contains data (loaded by the CPU) to be transmitted
  - TXSHF register transmitter shift register. Accepts data from register SCITXBUF and shifts data onto the SCITXD pin, one bit at a time
- A receiver (RX) and its major registers (lower half of Figure 11-2)
  - RXSHF register receiver shift register. Shifts data in from SCIRXD pin, one bit at a time
  - SCIRXBUF receiver data buffer register. Contains data to be read by the CPU. Data from a remote processor is loaded into register RXSHF and then into registers SCIRXBUF and SCIRXEMU

- A programmable baud generator
- Data-memory-mapped control and status registers

The SCI receiver and transmitter can operate either independently or simultaneously.

### 11.1.1.1 SCI Module Signal Summary

| Signal Name | Description                                |
|-------------|--------------------------------------------|
|             | External signals                           |
| SCIRXD      | SCI Asynchronous Serial Port receive data  |
| SCITXD      | SCI Asynchronous Serial Port transmit data |
|             | Control                                    |
| Baud clock  | LSPCLK Prescaled clock                     |
|             | Interrupt signals                          |
| TXINT       | Transmit interrupt                         |
| RXINT       | Receive Interrupt                          |

#### Table 11-1. SCI Module Signal Summary

### 11.1.1.2 Multiprocessor and Asynchronous Communication Modes

The SCI has two multiprocessor protocols, the idle-line multiprocessor mode (see Section 11.1.1.5) and the address-bit multiprocessor mode (see Section 11.1.1.6). These protocols allow efficient data transfer between multiple processors.

The SCI offers the universal asynchronous receiver/transmitter (UART) communications mode for interfacing with many popular peripherals. The asynchronous mode (see Section 11.1.1.7) requires two lines to interface with many standard devices such as terminals and printers that use RS-232-C formats. Data transmission characteristics include:

- One start bit
- One to eight data bits
- An even/odd parity bit or no parity bit
- One or two stop bits

### 11.1.1.3 SCI Programmable Data Format

SCI data, both receive and transmit, is in NRZ (non-return-to-zero) format. The NRZ data format, shown in Figure 11-3, consists of:

- One start bit
- One to eight data bits
- An even/odd parity bit (optional)
- One or two stop bits
- An extra bit to distinguish addresses from data (address-bit mode only)

The basic unit of data is called a character and is one to eight bits in length. Each character of data is formatted with a start bit, one or two stop bits, and optional parity and address bits. A character of data with its formatting information is called a frame and is shown in Figure 11-3.



To program the data format, use the SCICCR register. The bits used to program the data format are shown in Table 11-2.

| Bit(s) | Bit Name    | Designation | Functions                                                                                                 |
|--------|-------------|-------------|-----------------------------------------------------------------------------------------------------------|
| 2-0    | SCI CHAR2-0 | SCICCR.2:0  | Select the character (data) length (one to eight bits).                                                   |
| 5      | PARITY      | SCICCR.5    | Enables the parity function if set to 1, or disables the parity function                                  |
|        | ENABLE      |             | if cleared to 0.                                                                                          |
| 6      | EVEN/ODD    | SCICCR.6    | If parity is enabled, selects odd parity if cleared to 0 or even parity if                                |
|        | PARITY      |             | set to 1.                                                                                                 |
| 7      | STOP BITS   | SCICCR.7    | Determines the number of stop bits transmitted—one stop bit if cleared to 0 or two stop bits if set to 1. |

### 11.1.1.4 SCI Multiprocessor Communication

The multiprocessor communication format allows one processor to efficiently send blocks of data to other processors on the same serial link. On one serial line, there should be only one transfer at a time. In other words, there can be only one talker on a serial line at a time.

#### Address Byte

The first byte of a block of information that the talker sends contains an address byte that is read by all listeners. Only listeners with the correct address can be interrupted by the data bytes that follow the address byte. The listeners with an incorrect address remain uninterrupted until the next address byte.

#### Sleep Bit

All processors on the serial link set the SCI SLEEP bit (bit 2 of SCICTL1) to 1 so that they are interrupted only when the address byte is detected. When a processor reads a block address that corresponds to the CPU device address as set by your application software, your program must clear the SLEEP bit to enable the SCI to generate an interrupt on receipt of each data byte.

Although the receiver still operates when the SLEEP bit is 1, it does not set RXRDY, RXINT, or any of the receiver error status bits to 1 unless the address byte is detected and the address bit in the received frame is a 1 (applicable to address-bit mode). The SCI does not alter the SLEEP bit; your software must alter the SLEEP bit.

#### 11.1.1.4.1 Recognizing the Address Byte

A processor recognizes an address byte differently, depending on the multiprocessor mode used. For example:

- The idle-line mode (Section 11.1.1.5) leaves a quiet space before the address byte. This mode does
  not have an extra address/data bit and is more efficient than the address-bit mode for handling blocks
  that contain more than ten bytes of data. The idle-line mode should be used for typical nonmultiprocessor SCI communication.
- The address-bit mode (Section 11.1.1.6) adds an extra bit (that is, an address bit) into every byte to distinguish addresses from data. This mode is more efficient in handling many small blocks of data



because, unlike the idle mode, it does not have to wait between blocks of data. However, at a high transmit speed, the program is not fast enough to avoid a 10-bit idle in the transmission stream.

### 11.1.1.4.2 Controlling the SCI TX and RX Features

The multiprocessor mode is software selectable via the ADDR/IDLE MODE bit (SCICCR, bit 3). Both modes use the TXWAKE flag bit (SCICTL1, bit 3), RXWAKE flag bit (SCIRXST, bit1), and the SLEEP flag bit (SCICTL1, bit 2) to control the SCI transmitter and receiver features of these modes.

### 11.1.1.4.3 Receipt Sequence

In both multiprocessor modes, the receive sequence is:

- 1. At the receipt of an address block, the SCI port wakes up and requests an interrupt (bit number 1 RX/BK INT ENA-of SCICTL2 must be enabled to request an interrupt). It reads the first frame of the block, which contains the destination address.
- 2. A software routine is entered through the interrupt and checks the incoming address. This address byte is checked against its device address byte stored in memory.
- 3. If the check shows that the block is addressed to the device CPU, the CPU clears the SLEEP bit and reads the rest of the block; if not, the software routine exits with the SLEEP bit still set and does not receive interrupts until the next block start.

### 11.1.1.5 Idle-Line Multiprocessor Mode

In the idle-line multiprocessor protocol (ADDR/IDLE MODE bit=0), blocks are separated by having a longer idle time between the blocks than between frames in the blocks. An idle time of ten or more high-level bits after a frame indicates the start of a new block. The time of a single bit is calculated directly from the baud value (bits per second). The idle-line multiprocessor communication format is shown in Figure 11-4 (ADDR/IDLE MODE bit is bit 3 of SCICCR).



### Figure 11-4. Idle-Line Multiprocessor Communication Format

### 11.1.1.5.1 Idle-Line Mode Steps

The steps followed by the idle-line mode:

- Step 1. SCI wakes up after receipt of the block-start signal.
- Step 2. The processor recognizes the next SCI interrupt.
- Step 3. The interrupt service routine compares the received address (sent by a remote transmitter) to its own.
- Step 4. If the CPU is being addressed, the service routine clears the SLEEP bit and receives the rest of the data block.
- Step 5. If the CPU is not being addressed, the SLEEP bit remains set. This lets the CPU continue to execute its main program without being interrupted by the SCI port until the next detection of

Enhanced SCI Module Overview

TEXAS INSTRUMENTS

www.ti.com

a block start.

#### 11.1.1.5.2 Block Start Signal

There are two ways to send a block-start signal:

- 1. Method 1: Deliberately leave an idle time of ten bits or more by delaying the time between the transmission of the last frame of data in the previous block and the transmission of the address frame of the new block.
- Method 2: The SCI port first sets the TXWAKE bit (SCICTL1, bit 3) to 1 before writing to the SCITXBUF register. This sends an idle time of exactly 11 bits. In this method, the serial communications line is not idle any longer than necessary. (A don't care byte has to be written to SCITXBUF after setting TXWAKE, and before sending the address, so as to transmit the idle time.)

#### 11.1.1.5.3 Wake-UP Temporary (WUT) Flag

Associated with the TXWAKE bit is the wake-up temporary (WUT) flag. WUT is an internal flag, doublebuffered with TXWAKE. When TXSHF is loaded from SCITXBUF, WUT is loaded from TXWAKE, and the TXWAKE bit is cleared to 0. This arrangement is shown in Figure 11-5.

#### Figure 11-5. Double-Buffered WUT and TXSHF



A WUT = wake-up temporary

Sending a Block Start Signal

To send out a block-start signal of exactly one frame time during a sequence of block transmissions:

- 1. Write a 1 to the TXWAKE bit.
- 2. Write a data word (content not important: a don't care) to the SCITXBUF register (transmit data buffer) to send a block-start signal. (The first data word written is suppressed while the block-start signal is sent out and ignored after that.) When the TXSHF (transmit shift register) is free again, SCITXBUF contents are shifted to TXSHF, the TXWAKE value is shifted to WUT, and then TXWAKE is cleared.

Because TXWAKE was set to a 1, the start, data, and parity bits are replaced by an idle period of 11 bits transmitted following the last stop bit of the previous frame.

3. Write a new address value to SCITXBUF.

A don't-care data word must first be written to register SCITXBUF so that the TXWAKE bit value can be shifted to WUT. After the don't-care data word is shifted to the TXSHF register, the SCITXBUF (and TXWAKE if necessary) can be written to again because TXSHF and WUT are both double-buffered.

#### 11.1.1.5.4 Receiver Operation

The receiver operates regardless of the SLEEP bit. However, the receiver neither sets RXRDY nor the error status bits, nor does it request a receive interrupt until an address frame is detected.

#### 11.1.1.6 Address-Bit Multiprocessor Mode

In the address-bit protocol (ADDR/IDLE MODE bit=1), frames have an extra bit called an address bit that immediately follows the last data bit. The address bit is set to 1 in the first frame of the block and to 0 in all other frames. The idle period timing is irrelevant (see Figure 11-6).

#### 11.1.1.6.1 Sending an Address

The TXWAKE bit value is placed in the address bit. During transmission, when the SCITXBUF register and TXWAKE are loaded into the TXSHF register and WUT respectively, TXWAKE is reset to 0 and WUT becomes the value of the address bit of the current frame. Thus, to send an address:

- Set the TXWAKE bit to 1 and write the appropriate address value to the SCITXBUF register. When this address value is transferred to the TXSHF register and shifted out, its address bit is sent as a 1. This flags the other processors on the serial link to read the address.
- 2. Write to SCITXBUF and TXWAKE after TXSHF and WUT are loaded. (Can be written to immediately since both TXSHF and WUT are both double-buffered.
- 3. Leave the TXWAKE bit set to 0 to transmit non-address frames in the block.
  - **NOTE:** As a general rule, the address-bit format is typically used for data frames of 11 bytes or less. This format adds one bit value (1 for an address frame, 0 for a data frame) to all data bytes transmitted. The idle-line format is typically used for data frames of 12 bytes or more.



### Figure 11-6. Address-Bit Multiprocessor Communication Format

### 11.1.1.7 SCI Communication Format

The SCI asynchronous communication format uses either single line (one way) or two line (two way) communications. In this mode, the frame consists of a start bit, one to eight data bits, an optional even/odd parity bit, and one or two stop bits (shown in Figure 11-7). There are eight SCICLK periods per data bit.

The receiver begins operation on receipt of a valid start bit. A valid start bit is identified by four consecutive internal SCICLK periods of zero bits as shown in Figure 11-7. If any bit is not zero, then the processor starts over and begins looking for another start bit.

For the bits following the start bit, the processor determines the bit value by making three samples in the middle of the bits. These samples occur on the fourth, fifth, and sixth SCICLK periods, and bit-value determination is on a majority (two out of three) basis. Figure 11-7 illustrates the asynchronous communication format for this with a start bit showing where a majority vote is taken.



#### Enhanced SCI Module Overview

www.ti.com

Since the receiver synchronizes itself to frames, the external transmitting and receiving devices do not have to use a synchronized serial clock. The clock can be generated locally.

### Figure 11-7. SCI Asynchronous Communications Format



#### 11.1.1.7.1 Receiver Signals in Communication Modes

Figure 11-8 illustrates an example of receiver signal timing that assumes the following conditions:

- Address-bit wake-up mode (address bit does not appear in idle-line mode)
- Six bits per character

#### Figure 11-8. SCI RX Signals in Communication Modes



- (1) 2) Data arrives on the SCIRXD pin, start bit detected.
- (2) 6) Bit RXENA is brought low to disable the receiver. Data continues to be assembled in RXSHF but is not transferred to the receiver buffer register.

#### Notes:

- 1. Flag bit RXENA (SCICTL1, bit 0) goes high to enable the receiver.
- 2. Data arrives on the SCIRXD pin, start bit detected.
- 3. Data is shifted from RXSHF to the receiver buffer register (SCIRXBUF); an interrupt is requested. Flag bit RXRDY (SCIRXST, bit 6) goes high to signal that a new character has been received.
- 4. The program reads SCIRXBUF; flag RXRDY is automatically cleared.
- 5. The next byte of data arrives on the SCIRXD pin; the start bit is detected, then cleared.
- 6. Bit RXENA is brought low to disable the receiver. Data continues to be assembled in RXSHF but is not transferred to the receiver buffer register.

### 11.1.1.7.2 Transmitter Signals in Communication Modes

Figure 11-9 illustrates an example of transmitter signal timing that assumes the following conditions:

- Address-bit wake-up mode (address bit does not appear in idle-line mode)
- Three bits per character





### Figure 11-9. SCI TX Signals in Communications Mode

#### Notes:

- 1. Bit TXENA (SCICTL1, bit 1) goes high, enabling the transmitter to send data.
- 2. SCITXBUF is written to; thus, (1) the transmitter is no longer empty, and (2) TXRDY goes low.
- The SCI transfers data to the shift register (TXSHF). The transmitter is ready for a second character (TXRDY goes high), and it requests an interrupt (to enable an interrupt, bit TX INT ENA — SCICTL2, bit 0 — must be set).
- 4. The program writes a second character to SCITXBUF after TXRDY goes high (item 3). (TXRDY goes low again after the second character is written to SCITXBUF.)
- 5. Transmission of the first character is complete. Transfer of the second character to shift register TXSHF begins.
- 6. Bit TXENA goes low to disable the transmitter; the SCI finishes transmitting the current character.
- 7. Transmission of the second character is complete; transmitter is empty and ready for new character.

#### 11.1.1.8 SCI Port Interrupts

The SCI receiver and transmitter can be interrupt controlled. The SCICTL2 register has one flag bit (TXRDY) that indicates active interrupt conditions, and the SCIRXST register has two interrupt flag bits (RXRDY and BRKDT), plus the RX ERROR interrupt flag which is a logical OR of the FE, OE, BRKDT, and PE conditions. The transmitter and receiver have separate interrupt-enable bits. When not enabled, the interrupts are not asserted; however, the condition flags remain active, reflecting transmission and receipt status.

The SCI has independent peripheral interrupt vectors for the receiver and transmitter. Peripheral interrupt requests can be either high priority or low priority. This is indicated by the priority bits which are output from the peripheral to the PIE controller. When both RX and TX interrupt requests are made at the same priority level, the receiver always has higher priority than the transmitter, reducing the possibility of receiver overrun.

The operation of peripheral interrupts is described in the peripheral interrupt expansion controller section of the *System Control and Interrupts* chapter.

- If the RX/BK INT ENA bit (SCICTL2, bit 1) is set, the receiver peripheral interrupt request is asserted when one of the following events occurs:
  - The SCI receives a complete frame and transfers the data in the RXSHF register to the SCIRXBUF register. This action sets the RXRDY flag (SCIRXST, bit 6) and initiates an interrupt.
  - A break detect condition occurs (the SCIRXD is low for ten bit periods following a missing stop bit). This action sets the BRKDT flag bit (SCIRXST, bit 5) and initiates an interrupt.
- If the TX INT ENA bit (SCICTL2.0) is set, the transmitter peripheral interrupt request is asserted whenever the data in the SCITXBUF register is transferred to the TXSHF register, indicating that the CPU can write to SCITXBUF; this action sets the TXRDY flag bit (SCICTL2, bit 7) and initiates an interrupt.



**NOTE:** Interrupt generation due to the RXRDY and BRKDT bits is controlled by the RX/BK INT ENA bit (SCICTL2, bit 1). Interrupt generation due to the RX ERROR bit is controlled by the RX ERR INT ENA bit (SCICTL1, bit 6).

#### 11.1.1.9 SCI Baud Rate Calculations

The internally generated serial clock is determined by the low-speed peripheral clock LSPCLK) and the baud-select registers. The SCI uses the 16-bit value of the baud-select registers to select one of the 64K different serial clock rates possible for a given LSPCLK.

See the bit descriptions in Section 11.2.4, for the formula to use when calculating the SCI asynchronous baud. Table 11-3 shows the baud-select values for common SCI bit rates.

|            | L         | SPCLK Clock Frequency, 15 MH | z       |
|------------|-----------|------------------------------|---------|
| Ideal Baud | BRR       | Actual Baud                  | % Error |
| 2400       | 780(30Ch) | 2401                         | 0.03    |
| 4800       | 390(186h) | 4795                         | -0.10   |
| 9600       | 194(C2h)  | 9615                         | 0.16    |
| 19200      | 97(61h)   | 19133                        | -0.35   |
| 38400      | 48(30h)   | 38265                        | -0.35   |

Table 11-3. Asynchronous Baud Register Values for Common SCI Bit Rates

### 11.1.1.10 SCI Enhanced Features

The SCI features autobaud detection and transmit/receive FIFO. The following section explains the FIFO operation.

### 11.1.1.10.1 SCI FIFO Description

The following steps explain the FIFO features and help with programming the SCI with FIFOs.

- 1. *Reset.* At reset the SCI powers up in standard SCI mode and the FIFO function is disabled. The FIFO registers SCIFFTX, SCIFFRX, and SCIFFCT remain inactive.
- 2. *Standard SCI.* The standard F24x SCI modes will work normally with TXINT/RXINT interrupts as the interrupt source for the module.
- 3. *FIFO enable.* FIFO mode is enabled by setting the SCIFFEN bit in the SCIFFTX register. SCIRST can reset the FIFO mode at any stage of its operation.
- 4. Active registers. All the SCI registers and SCI FIFO registers (SCIFFTX, SCIFFRX, and SCIFFCT) are active.
- Interrupts. FIFO mode has two interrupts; one for transmit FIFO, TXINT and one for receive FIFO, RXINT. RXINT is the common interrupt for SCI FIFO receive, receive error, and receive FIFO overflow conditions. The TXINT of the standard SCI will be disabled and this interrupt will service as SCI transmit FIFO interrupt.
- 6. Buffers. Transmit and receive buffers are supplemented with two 4-level FIFOs. The transmit FIFO registers are 8 bits wide and receive FIFO registers are 10 bits wide. The one-word transmit buffer of the standard SCI, functions as a transition buffer between the transmit FIFO and shift register. The one word transmit buffer is loaded from transmit FIFO only after the last bit of the shift register is shifted out. With the FIFO enabled, TXSHF is directly loaded after an optional delay value (SCIFFCT), TXBUF is not used. When FIFO mode is enabled for SCI, characters written to SCITXBUF are queued in to SCI-TXFIFO and the characters received in SCI-RXFIFO can be read using SCIRXBUF.
- 7. Delayed transfer. The rate at which words in the FIFO are transferred to the transmit shift register is programmable. The SCIFFCT register bits (7–0) FFTXDLY7–FFTXDLY0 define the delay between the word transfer. The delay is defined in the number SCI baud clock cycles. The 8 bit register can define a minimum delay of 0 baud clock cycles and a maximum of 256-baud clock cycles. With zero delay, the SCI module can transmit data in continuous mode with the FIFO words shifting out back to back. With the 256 clock delay the SCI module can transmit data in a maximum delayed mode with the FIFO words shifting out with a delay of 256 baud clocks between each words. The programmable delay facilitates communication with slow SCI/UARTs with little CPU intervention.
- 8. *FIFO status bits.* Both the transmit and receive FIFOs have status bits TXFFST or RXFFST (bits 12–0) that define the number of words available in the FIFOs at any time. The transmit FIFO reset bit TXFIFO and receive reset bit RXFIFO reset the FIFO pointers to zero when these bits are cleared to 0. The FIFOs resumes operation from start once these bits are set to one.
- 9. *Programmable interrupt levels.* Both transmit and receive FIFO can generate CPU interrupts. The interrupt trigger is generated whenever the transmit FIFO status bits TXFFST (bits 12–8) match (less than or equal to) the interrupt trigger level bits TXFFIL (bits 4–0). This provides a programmable interrupt trigger for transmit and receive sections of the SCI. Default value for these trigger level bits will be 0x11111 for receive FIFO and 0x00000 for transmit FIFO, respectively.

Figure 11-10 and Table 11-4 explain the operation/configuration of SCI interrupts in nonFIFO/FFO mode.





Figure 11-10. SCI FIFO Interrupt Flags and Enable Logic



| FIFO Options <sup>(1)</sup> | SCI Interrupt Source            | Interrupt Flags      | Interrupt Enables  | FIFO Enable<br>SCIFFENA | Interrupt Line |
|-----------------------------|---------------------------------|----------------------|--------------------|-------------------------|----------------|
| SCI without FIFO            | Receive error                   | RXERR <sup>(2)</sup> | RXERRINTENA        | 0                       | RXINT          |
|                             | Receive break                   | BRKDT                | <b>RX/BKINTENA</b> | 0                       | RXINT          |
|                             | Data receive                    | RXRDY                | <b>RX/BKINTENA</b> | 0                       | RXINT          |
|                             | Transmit empty                  | TXRDY                | TXINTENA           | 0                       | TXINT          |
| SCI with FIFO               | Receive error and receive break | RXERR                | RXERRINTENA        | 1                       | RXINT          |
|                             | FIFO receive                    | RXFFIL               | RXFFIENA           | 1                       | RXINT          |
|                             | Transmit empty                  | TXFFIL               | TXFFIENA           | 1                       | TXINT          |
| Auto-baud                   | Auto-baud detected              | ABD                  | Don't care         | x                       | TXINT          |

<sup>(1)</sup> FIFO mode TXSHF is directly loaded after delay value, TXBUF is not used.

<sup>(2)</sup> RXERR can be set by BRKDT, FE, OE, PE flags. In FIFO mode, BRKDT interrupt is only through RXERR flag

### 11.1.1.10.2 SCI Auto-Baud

Most SCI modules do not have an auto-baud detect logic built-in hardware. These SCI modules are integrated with embedded controllers whose clock rates are dependent on PLL reset values. Often embedded controller clocks change after final design. In the enhanced feature set this module supports an autobaud-detect logic in hardware. The following section explains the enabling sequence for autobaud-detect feature.



Bits ABD and CDC in SCIFFCT control the autobaud logic. The SCIRST bit should be enabled to make autobaud logic work.

If ABD is set while CDC is 1, which indicates auto-baud alignment, SCI transmit FIFO interrupt will occur (TXINT). After the interrupt service CDC bit has to be cleared by software. If CDC remains set even after interrupt service, there should be no repeat interrupts.

- 1. Enable autobaud-detect mode for the SCI by setting the CDC bit (bit 13) in SCIFFCT and clearing the ABD bit (Bit 15) by writing a 1 to ABDCLR bit (bit 14).
- 2. Initialize the baud register to be 1 or less than a baud rate limit of 500 Kbps.
- 3. Allow SCI to receive either character "A" or "a" from a host at the desired baud rate. If the first character is either "A" or "a". the autobaud- detect hardware will detect the incoming baud rate and set the ABD bit.
- 4. The auto-detect hardware will update the baud rate register with the equivalent baud value hex. The logic will also generate an interrupt to the CPU.
- 5. Respond to the interrupt clear ADB bit by writing a 1 to ABD CLR (bit 14) of SCIFFCT register and disable further autobaud locking by clearing CDC bit by writing a 0.
- 6. Read the receive buffer for character "A" or "a" to empty the buffer and buffer status.
- 7. If ABD is set while CDC is 1, which indicates autobaud alignment, the SCI transmit FIFO interrupt will occur (TXINT). After the interrupt service CDC bit must be cleared by software.
  - **NOTE:** At higher baud rates, the slew rate of the incoming data bits can be affected by transceiver and connector performance. While normal serial communications may work well, this slew rate may limit reliable autobaud detection at higher baud rates (typically beyond 100k baud) and cause the auto-baudlock feature to fail.

To avoid this, the followng is recommended:

- Achieve a baud-lock between the host and SCI boot loader using a lower baud rate.
- The host may then handshake with the loaded device application to set the SCI baud rate register to the desired higher baud rate.

### 11.2 SCI Registers

The functions of the SCI are software configurable. Sets of control bits, organized into dedicated bytes, are programmed to initialize the desired SCI communications format. This includes operating mode and protocol, baud value, character length, even/odd parity or no parity, number of stop bits, and interrupt priorities and enables.

### 11.2.1 SCI Module Register Summary

The SCI is controlled and accessed through registers listed in Table 11-5 and Table 11-6, which are described in the sections that follow.

| Register Mnemonic      | Address     | Number of Bits | Description                                  |
|------------------------|-------------|----------------|----------------------------------------------|
| SCICCR                 | 0x0000-7050 | 1              | SCI-A Communications Control Register        |
| SCICTL1                | 0x0000-7051 | 1              | SCI-A Control Register 1                     |
| SCIHBAUD               | 0x0000-7052 | 1              | SCI-A Baud Register, High Bits               |
| SCILBAUD               | 0x0000-7053 | 1              | SCI-A Baud Register, Low Bits                |
| SCICTL2                | 0x0000-7054 | 1              | SCI-A Control Register 2                     |
| SCIRXST                | 0x0000-7055 | 1              | SCI-A Receive Status Register                |
| SCIRXEMU               | 0x0000-7056 | 1              | SCI-A Receive Emulation Data Buffer Register |
| SCIRXBUF               | 0x0000-7057 | 1              | SCI-A Receive Data Buffer Register           |
| SCITXBUF               | 0x0000-7059 | 1              | SCI-A Transmit Data Buffer Register          |
| SCIFFTX <sup>(1)</sup> | 0x0000-705A | 1              | SCI-A FIFO Transmit Register                 |
| SCIFFRX <sup>(1)</sup> | 0x0000-705B | 1              | SCI-A FIFO Receive Register                  |
| SCIFFCT <sup>(1)</sup> | 0x0000-705C | 1              | SCI-A FIFO Control Register                  |
| SCIPRI                 | 0x0000-705F | 1              | SCI-A Priority Control Register              |

| Table | 11-5. | SCI-A | Registers |
|-------|-------|-------|-----------|
|-------|-------|-------|-----------|

<sup>(1)</sup> These registers operate in enhanced mode.

#### Table 11-6. SCI-B Registers

|          | 5             |                |                                              |  |  |  |  |
|----------|---------------|----------------|----------------------------------------------|--|--|--|--|
| Name     | Address Range | Number of Bits | Description <sup>(1)</sup>                   |  |  |  |  |
| SCICCR   | 0x0000-7750   | 1              | SCI-B Communications Control Register        |  |  |  |  |
| SCICTL1  | 0x0000-7751   | 1              | SCI-B Control Register 1                     |  |  |  |  |
| SCIHBAUD | 0x0000-7752   | 1              | SCI-B Baud Register, High Bits               |  |  |  |  |
| SCILBAUD | 0x0000-7753   | 1              | SCI-B Baud Register, Low Bits                |  |  |  |  |
| SCICTL2  | 0x0000-7754   | 1              | SCI-B Control Register 2                     |  |  |  |  |
| SCIRXST  | 0x0000-7755   | 1              | SCI-B Receive Status Register                |  |  |  |  |
| SCIRXEMU | 0x0000-7756   | 1              | SCI-B Receive Emulation Data Buffer Register |  |  |  |  |
| SCIRXBUF | 0x0000-7567   | 1              | SCI-B Receive Data Buffer Register           |  |  |  |  |
| SCITXBUF | 0x0000-7569   | 1              | SCI-B Transmit Data Buffer Register          |  |  |  |  |
| SCIFFTX  | 0x0000-775A   | 1              | SCI-B FIFO Transmit Register                 |  |  |  |  |
| SCIFFRX  | 0x0000-775B   | 1              | SCI-B FIFO Receive Register                  |  |  |  |  |
| SCIFFCT  | 0x0000-775C   | 1              | SCI-B FIFO Control Register                  |  |  |  |  |
| SCIPRI   | 0x0000-775F   | 1              | SCI-B Priority Control Register              |  |  |  |  |
| (4)      |               |                |                                              |  |  |  |  |

<sup>(1)</sup> These registers are mapped to peripheral frame 2. This frame allows only 16-bit accesses.

### Table 11-7. SCIC Registers

| Name    | Address Range | Number of Bits | Description <sup>(1)</sup>            |
|---------|---------------|----------------|---------------------------------------|
| SCICCR  | 0x0000-7770   | 1              | SCI-B Communications Control Register |
| SCICTL1 | 0x0000-7771   | 1              | SCI-B Control Register 1              |

<sup>(1)</sup> These registers are mapped to peripheral frame 2. This frame allows only 16-bit accesses.



| Name     | Address Range | Number of Bits                        | Description <sup>(1)</sup>                   |
|----------|---------------|---------------------------------------|----------------------------------------------|
| SCIHBAUD | 0x0000-7772   | 1                                     | SCI-B Baud Register, High Bits               |
| SCILBAUD | 0x0000-7773   | 1                                     | SCI-B Baud Register, Low Bits                |
| SCICTL2  | 0x0000-7774   | 1                                     | SCI-B Control Register 2                     |
| SCIRXST  | 0x0000-7775   | 1                                     | SCI-B Receive Status Register                |
| SCIRXEMU | 0x0000-7776   | 1                                     | SCI-B Receive Emulation Data Buffer Register |
| SCIRXBUF | 0x0000-7777   | 1                                     | SCI-B Receive Data Buffer Register           |
| SCITXBUF | 0x0000-7779   | 1 SCI-B Transmit Data Buffer Register |                                              |
| SCIFFTX  | 0x0000-777A   | 1                                     | SCI-B FIFO Transmit Register                 |
| SCIFFRX  | 0x0000-777B   | 1                                     | SCI-B FIFO Receive Register                  |
| SCIFFCT  | 0x0000-777C   | 1                                     | SCI-B FIFO Control Register                  |
| SCIPRI   | 0x0000-777F   | 1                                     | SCI-B Priority Control Register              |
|          |               |                                       |                                              |

### Table 11-7. SCIC Registers (continued)

Texas Instruments

www.ti.com

SCI Registers

### 11.2.2 SCI Communication Control Register (SCICCR)

SCICCR defines the character format, protocol, and communications mode used by the SCI.

### Figure 11-11. SCI Communication Control Register (SCICCR) — Address 7050h

| 7         | 6                  | 5                | 4               | 3                 | 2        | 1        | 0        |
|-----------|--------------------|------------------|-----------------|-------------------|----------|----------|----------|
| STOP BITS | EVEN/ODD<br>PARITY | PARITY<br>ENABLE | LOOPBACK<br>ENA | ADDR/IDLE<br>MODE | SCICHAR2 | SCICHAR1 | SCICHAR0 |
| R/W-0     | R/W-0              | R/W-0            | R/W-0           | R/W-0             | R/W-0    | R/W-0    | R/W-0    |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 11-8. SCI Communication Control Register (SCICCR) Field Descriptions

| Bit | Field           | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                | Description                               |                                                                                                                             |  |  |  |  |
|-----|-----------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7   | STOP BITS       |       | SCI number of stop b checks for only one s                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                | the number of stop                        | bits transmitted. The receiver                                                                                              |  |  |  |  |
|     |                 | 0     | One stop bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
|     |                 | 1     | Two stop bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
| 6   | EVEN/ODD PARITY |       | 6) designates odd or                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | SCI parity odd/even selection. If the PARITY ENABLE bit (SCICCR, bit 5) is set, PARITY (bi<br>6) designates odd or even parity (odd or even number of bits with the value of 1 in both<br>ransmitted and received characters). |                                           |                                                                                                                             |  |  |  |  |
|     |                 | 0     | Odd parity                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
|     |                 | 1     | Even parity                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
| 5   | PARITY ENABLE   |       | SCI parity enable. This bit enables or disables the parity function. If the SCI is in the addr<br>bit multiprocessor mode (set using bit 3 of this register), the address bit is included in the<br>parity calculation (if parity is enabled). For characters of less than eight bits, the remaining<br>unused bits should be masked out of the parity calculation.                                                                                                                     |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
|     |                 | 0     | Parity disabled; no pa                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | rity bit is generated                                                                                                                                                                                                          | during transmission                       | or is expected during reception                                                                                             |  |  |  |  |
|     |                 | 1     | Parity is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
| 4   | LOOP BACK ENA   |       | Loop Back test mode<br>internally connected to                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                | bles the Loop Back                        | test mode where the Tx pin is                                                                                               |  |  |  |  |
|     |                 | 0     | Loop Back test mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
|     |                 | 1     | Loop Back test mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | enabled                                                                                                                                                                                                                        |                                           |                                                                                                                             |  |  |  |  |
| 3   | ADDR/IDLE MODE  |       | SCI multiprocessor mode control bit. This bit selects one of the multiprocessor protoco<br>Multiprocessor communication is different from the other communication modes becau<br>uses SLEEP and TXWAKE functions (bits SCICTL1, bit 2 and SCICTL1, bit 3, respect<br>The idle-line mode is usually used for normal communications because the address-b<br>adds an extra bit to the frame. The idle-line mode does not add this extra bit and is co<br>with RS-232 type communications. |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
|     |                 | 0     | Idle-line mode protoco                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ol selected                                                                                                                                                                                                                    |                                           |                                                                                                                             |  |  |  |  |
|     |                 | 1     | Address-bit mode pro                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | tocol selected                                                                                                                                                                                                                 |                                           |                                                                                                                             |  |  |  |  |
| 2-0 | SCI CHAR2-0     |       | bits. Characters of les<br>are padded with leadi                                                                                                                                                                                                                                                                                                                                                                                                                                        | s than eight bits are<br>ng zeros in SCIRXB                                                                                                                                                                                    | right-justified in SC<br>UF. SCITXBUF doe | haracter length from one to eight<br>IRXBUF and SCIRXEMU and<br>esn't need to be padded with<br>HAR2-0 bits are as follows: |  |  |  |  |
|     |                 |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SCI CHAR2-0 B                                                                                                                                                                                                                  | it Values (Binary)                        |                                                                                                                             |  |  |  |  |
|     |                 |       | SCI CHAR2 SCI CHAR1 SCI CHAR0 Character<br>Length (Bits)                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                |                                           |                                                                                                                             |  |  |  |  |
|     |                 |       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                              | 0                                         | 1                                                                                                                           |  |  |  |  |
|     |                 |       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                              | 1                                         | 2                                                                                                                           |  |  |  |  |
|     |                 |       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                              | 0                                         | 3                                                                                                                           |  |  |  |  |
|     |                 |       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                              | 1                                         | 4                                                                                                                           |  |  |  |  |
|     |                 |       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                              | 0                                         | 5                                                                                                                           |  |  |  |  |
|     |                 |       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                              | 1                                         | 6                                                                                                                           |  |  |  |  |
|     |                 |       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                              | 0                                         | 7                                                                                                                           |  |  |  |  |
|     |                 |       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                              | 1                                         | 8                                                                                                                           |  |  |  |  |



R-0

R/W-0

### 11.2.3 SCI Control Register 1 (SCICTL1)

SCICTL1 controls the receiver/transmitter enable, TXWAKE and SLEEP functions, and the SCI software reset.

| Figure 11-12. SCI Control Register 1 (SCICTL1) — Address 7051n |                   |          |          |        |       |       |       |  |
|----------------------------------------------------------------|-------------------|----------|----------|--------|-------|-------|-------|--|
| 7                                                              | 6                 | 5        | 4        | 3      | 2     | 1     | 0     |  |
| Reserved                                                       | RX ERR INT<br>ENA | SW RESET | Reserved | TXWAKE | SLEEP | TXENA | RXENA |  |

R-0

#### 70544 TAL Deviator 4 (COLOTI 4) ممعداما 40

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

R/W-0

R/W-0

### Table 11-9. SCI Control Register 1 (SCICTL1) Field Descriptions

R/S-0

R/W-0

R/W-0

| Bit | Field             | Valu<br>e | Description                                                                                                                                                                    |                                                                                                                                                                                                                                             |                                                                                                               |  |  |  |  |  |  |
|-----|-------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 7   | Reserved          |           | Reads return zero; writes have no effect.                                                                                                                                      |                                                                                                                                                                                                                                             |                                                                                                               |  |  |  |  |  |  |
| 6   | RX ERR INT<br>ENA |           |                                                                                                                                                                                | CI receive error interrupt enable. Setting this bit enables an interrupt if the RX ERROR bit (SCIRXST, bit 7) comes set because of errors occurring.                                                                                        |                                                                                                               |  |  |  |  |  |  |
|     |                   | 0         | Receive error interrup                                                                                                                                                         | eive error interrupt disabled                                                                                                                                                                                                               |                                                                                                               |  |  |  |  |  |  |
|     |                   | 1         | Receive error interrup                                                                                                                                                         | eive error interrupt enabled                                                                                                                                                                                                                |                                                                                                               |  |  |  |  |  |  |
| 5   | SW RESET          |           | (registers SCICTL2 at<br>The SW RESET bit d<br>All affected logic is he<br>a reset are shown be<br>SCI by writing a 1 to t<br>Clear this bit after a re<br>SW RESET affects th | a receiver break detect (BRKDT flag, bit SCIRXST, bit 5).<br>ts the operating flags of the SCI, but it neither affects the configuration bits nor restores the<br>e SW RESET is asserted, the flags are frozen until the bit is deasserted. |                                                                                                               |  |  |  |  |  |  |
|     |                   |           | Value After SW<br>RESET                                                                                                                                                        | SCI Flag                                                                                                                                                                                                                                    | Register Bit                                                                                                  |  |  |  |  |  |  |
|     |                   |           | 1                                                                                                                                                                              | TXRDY                                                                                                                                                                                                                                       | SCICTL2, bit 7                                                                                                |  |  |  |  |  |  |
|     |                   |           | 1                                                                                                                                                                              | TX EMPTY                                                                                                                                                                                                                                    | SCICTL2, bit 6                                                                                                |  |  |  |  |  |  |
|     |                   |           | 0                                                                                                                                                                              | RXWAKE                                                                                                                                                                                                                                      | SCIRXST, bit 1                                                                                                |  |  |  |  |  |  |
|     |                   |           | 0                                                                                                                                                                              | PE                                                                                                                                                                                                                                          | SCIRXST, bit 2                                                                                                |  |  |  |  |  |  |
|     |                   |           | 0                                                                                                                                                                              | OE                                                                                                                                                                                                                                          | SCIRXST, bit 3                                                                                                |  |  |  |  |  |  |
|     |                   |           | 0                                                                                                                                                                              | FE                                                                                                                                                                                                                                          | SCIRXST, bit 4                                                                                                |  |  |  |  |  |  |
|     |                   |           | 0                                                                                                                                                                              | BRKDT                                                                                                                                                                                                                                       | SCIRXST, bit 5                                                                                                |  |  |  |  |  |  |
|     |                   |           | 0                                                                                                                                                                              | RXRDY                                                                                                                                                                                                                                       | SCIRXST, bit 6                                                                                                |  |  |  |  |  |  |
|     |                   |           | 0                                                                                                                                                                              | RX ERROR                                                                                                                                                                                                                                    | SCIRXST, bit 7                                                                                                |  |  |  |  |  |  |
|     |                   | 0         | Writing a 0 to this bit SCIRXST) to the rese                                                                                                                                   |                                                                                                                                                                                                                                             | chines and operating flags (registers SCICTL2 and                                                             |  |  |  |  |  |  |
|     |                   | 1         | After a system reset,                                                                                                                                                          | re-enable the SCI by writin                                                                                                                                                                                                                 | g a 1 to this bit.                                                                                            |  |  |  |  |  |  |
| 4   | Reserved          |           | Reads return zero; wr                                                                                                                                                          | rites have no effect.                                                                                                                                                                                                                       |                                                                                                               |  |  |  |  |  |  |
| 3   | TXWAKE            |           |                                                                                                                                                                                |                                                                                                                                                                                                                                             | WAKE bit controls selection of the data-transmit feature, address-bit) is specified at the ADDR/IDLE MODE bit |  |  |  |  |  |  |
|     |                   | 0         | SCITXBUF to genera                                                                                                                                                             | is not selected. In idle-line mode: write a 1 to TXWAKE, then write data to register enerate an idle period of 11 data bits In address-bit mode: write a 1 to TXWAKE, then write JF to set the address bit for that frame to 1              |                                                                                                               |  |  |  |  |  |  |
|     |                   | 1         | Transmit feature sele                                                                                                                                                          | cted is dependent on the m                                                                                                                                                                                                                  | node, idle-line or address-bit:                                                                               |  |  |  |  |  |  |
|     |                   |           | TXWAKE is not clear<br>transfer of TXWAKE t                                                                                                                                    |                                                                                                                                                                                                                                             | SCICTL1, bit 5); it is cleared by a system reset or the                                                       |  |  |  |  |  |  |

| Bit | Field | Valu | ription                                                                                                                                                                                                                                                                                                                                                                                      |  |
|-----|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|     |       | е    |                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 2   | SLEEP |      | SCI sleep. The TXWAKE bit controls selection of the data-transmit feature, depending on which transmit mode (idle-line or address-bit) is specified at the ADDR/IDLE MODE bit (SCICCR, bit 3). In a multiprocessor configuration, this bit controls the receiver sleep function. Clearing this bit brings the SCI out of the sleep mode.                                                     |  |
|     |       |      | The receiver still operates when the SLEEP bit is set; however, operation does not update the receiver buffer ready bit (SCIRXST, bit 6, RXRDY) or the error status bits (SCIRXST, bit 5–2: BRKDT, FE, OE, and PE) unless the address byte is detected. SLEEP is not cleared when the address byte is detected.                                                                              |  |
|     |       | 0    | Sleep mode disabled                                                                                                                                                                                                                                                                                                                                                                          |  |
|     |       | 1    | Sleep mode enabled                                                                                                                                                                                                                                                                                                                                                                           |  |
| 1   | TXENA |      | SCI transmitter enable. Data is transmitted through the SCITXD pin only when TXENA is set. If reset, transmission is halted but only after all data previously written to SCITXBUF has been sent.                                                                                                                                                                                            |  |
|     |       | 0    | Transmitter disabled0                                                                                                                                                                                                                                                                                                                                                                        |  |
|     |       | 1    | Transmitter enabled                                                                                                                                                                                                                                                                                                                                                                          |  |
| 0   | RXENA |      | SCI receiver enable. Data is received on the SCIRXD pin and is sent to the receiver shift register and then the receiver buffers. This bit enables or disables the receiver (transfer to the buffers).                                                                                                                                                                                       |  |
|     |       |      | Clearing RXENA stops received characters from being transferred to the two receiver buffers and also stops the generation of receiver interrupts. However, the receiver shift register can continue to assemble characters. Thus, if RXENA is set during the reception of a character, the complete character will be transferred into the receiver buffer registers, SCIRXEMU and SCIRXBUF. |  |
|     |       | 0    | Prevent received characters from transfer into the SCIRXEMU and SCIRXBUF receiver buffers                                                                                                                                                                                                                                                                                                    |  |
|     |       | 1    | Send received characters to SCIRXEMU and SCIRXBUF                                                                                                                                                                                                                                                                                                                                            |  |

### Table 11-9. SCI Control Register 1 (SCICTL1) Field Descriptions (continued)



### 11.2.4 SCI Baud-Select Registers (SCIHBAUD, SCILBAUD)

The values in SCIHBAUD and SCILBAUD specify the baud rate for the SCI.

## Figure 11-13. Baud-Select MSbyte Register (SCIHBAUD) — Address 7052h

| 15                                                             | 14     | 13     | 12     | 11     | 10     | 9     | 8     |  |  |  |
|----------------------------------------------------------------|--------|--------|--------|--------|--------|-------|-------|--|--|--|
| BAUD15 (MSB)                                                   | BAUD14 | BAUD13 | BAUD12 | BAUD11 | BAUD10 | BAUD9 | BAUD8 |  |  |  |
| R/W-0                                                          | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0 | R/W-0 |  |  |  |
| LEGEND: RAV - Read Avita: R - Read only: n - value after reset |        |        |        |        |        |       |       |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Figure 11-14. Baud-Select LSbyte Register (SCILBAUD) — Address 7053h

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0            |
|-------|-------|-------|-------|-------|-------|-------|--------------|
| BAUD7 | BAUD6 | BAUD5 | BAUD4 | BAUD3 | BAUD2 | BAUD1 | BAUD10 (LSB) |
| R/W-0        |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 11-10. Baud-Select Register Field Descriptions

| Bit  | Field         | Value | Description                                                                                                                                                                                                                                                  |      |
|------|---------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 15-0 | BAUD15- BAUD0 |       | SCI 16-bit baud selection Registers SCIHBAUD (MSbyte) and SCILBAUD (LSbyte) are concatenated to form a 16-bit baud value, BRR.                                                                                                                               |      |
|      |               |       | The internally-generated serial clock is determined by the low speed peripheral clock (LSPCLK) signal and the two baud-select registers. The SCI uses the 16-bit value of these registers to sele one of 64K serial clock rates for the communication modes. |      |
|      |               |       | The SCI baud rate is calculated using the following equation:                                                                                                                                                                                                |      |
|      |               |       | SCI Asynchronous Baud = $\frac{\text{LSPCLK}}{(\text{BRR + 1}) \times 8}$                                                                                                                                                                                    | (8)  |
|      |               |       | Alternatively,                                                                                                                                                                                                                                               |      |
|      |               |       | $BRR = \frac{LSPCLK}{SCI A synchronous Baud \times 8} - 1$                                                                                                                                                                                                   | (9)  |
|      |               |       | Note that the above formulas are applicable only when $1 \leq BRR \leq 65535$ . If BRR = 0, then                                                                                                                                                             |      |
|      |               |       | SCI Asynchronous Baud = $\frac{\text{LSPCLK}}{16}$                                                                                                                                                                                                           | (10) |
|      |               |       | Where: BRR = the 16-bit value (in decimal) in the baud-select registers.                                                                                                                                                                                     |      |



SCI Registers

### 11.2.5 SCI Control Register 2 (SCICTL2)

SCICTL2 enables the receive-ready, break-detect, and transmit-ready interrupts as well as transmitterready and -empty flags.

| 7     | 6        | 5 |          | 2 | 1                | 0          |
|-------|----------|---|----------|---|------------------|------------|
| TXRDY | TX EMPTY |   | Reserved |   | RX/BK INT<br>ENA | TX INT ENA |
| R-1   | R-1      |   | R-0      |   | R/W-0            | R/W-0      |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

| Bit | Field         | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|---------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | TXRDY         |       | Transmitter buffer register ready flag. When set, this bit indicates that the transmit data buffer register, SCITXBUF, is ready to receive another character. Writing data to the SCITXBUF automatically clears this bit. When set, this flag asserts a transmitter interrupt request if the interrupt-enable bit, TX INT ENA (SCICTL2.0), is also set. TXRDY is set to 1 by enabling the SW RESET bit (SCICTL1.5) or by a system reset. |
|     |               | 0     | SCITXBUF is full                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |               | 1     | SCITXBUF is ready to receive the next character                                                                                                                                                                                                                                                                                                                                                                                          |
| 6   | TX EMPTY      |       | Transmitter empty flag. This flag's value indicates the contents of the transmitter's buffer register (SCITXBUF) and shift register (TXSHF). An active SW RESET (SCICTL1.5), or a system reset, sets this bit. This bit does not cause an interrupt request.                                                                                                                                                                             |
|     |               | 0     | Transmitter buffer or shift register or both are loaded with data                                                                                                                                                                                                                                                                                                                                                                        |
|     |               | 1     | Transmitter buffer and shift registers are both empty                                                                                                                                                                                                                                                                                                                                                                                    |
| 5-2 | Reserved      |       |                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1   | RX/BK INT ENA |       | Receiver-buffer/break interrupt enable. This bit controls the interrupt request caused by either the RXRDY flag or the BRKDT flag (bits SCIRXST.6 and .5) being set. However, RX/BK INT ENA does not prevent the setting of these flags.                                                                                                                                                                                                 |
|     |               | 0     | Disable RXRDY/BRKDT interrupt                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |               | 1     | Enable RXRDY/BRKDT interrupt                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0   | TX INT ENA    |       | SCITXBUF-register interrupt enable. This bit controls the interrupt request caused by setting the TXRDY flag bit (SCICTL2.7). However, it does not prevent the TXRDY flag from being set (being set indicates that register SCITXBUF is ready to receive another character).                                                                                                                                                             |
|     |               | 0     | Disable TXRDY interrupt                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |               | 1     | Enable TXRDY interrupt                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 11.2.6 SCI Receiver Status Register (SCIRXST)

SCIRXST contains seven bits that are receiver status flags (two of which can generate interrupt requests). Each time a complete character is transferred to the receiver buffers (SCIRXEMU and SCIRXBUF), the status flags are updated. Figure 11-17 shows the relationships between several of the register's bits.

| Figure 11-16. SCI Receiver Status Register (SCIRXST) — Addres |
|---------------------------------------------------------------|
|---------------------------------------------------------------|

|          | -     |       |     |     |     |        |          |
|----------|-------|-------|-----|-----|-----|--------|----------|
| 7        | 6     | 5     | 4   | 3   | 2   | 1      | 0        |
| RX ERROR | RXRDY | BRKDT | FE  | OE  | PE  | RXWAKE | Reserved |
| R-0      | R-0   | R-0   | R-0 | R-0 | R-0 | R-0    | R-0      |
|          |       |       |     |     |     |        |          |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



| Bit | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RX ERROR |       | SCI receiver error flag. The RX ERROR flag indicates that one of the error flags in the receiver status register is set. RX ERROR is a logical OR of the break detect, framing error, overrun, and parity error enable flags (bits 5–2: BRKDT, FE, OE, and PE).                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |          |       | A 1 on this bit will cause an interrupt if the RX ERR INT ENA bit (SCICTL1.6) is set. This bit can be used for fast error-condition checking during the interrupt service routine. This error flag cannot be cleared directly; it is cleared by an active SW RESET or by a system reset.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | 0     | No error flags set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |          | 1     | Error flag(s) set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6   | RXRDY    |       | SCI receiver-ready flag. When a new character is ready to be read from the SCIRXBUF register, the receiver sets this bit, and a receiver interrupt is generated if the RX/BK INT ENA bit (SCICTL2.1) is a 1. RXRDY is cleared by a reading of the SCIRXBUF register, by an active SW RESET, or by a system reset.                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |          | 0     | No new character in SCIRXBUF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |          | 1     | Character ready to be read from SCIRXBUF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5   | BRKDT    |       | SCI break-detect flag. The SCI sets this bit when a break condition occurs. A break condition occurs when the SCI receiver data line (SCIRXD) remains continuously low for at least ten bits, beginning after a missing first stop bit. The occurrence of a break causes a receiver interrupt to be generated if the RX/BK INT ENA bit is a 1, but it does not cause the receiver buffer to be loaded. A BRKDT interrupt can occur even if the receiver SLEEP bit is set to 1. BRKDT is cleared by an active SW RESET or by a system reset. It is not cleared by receipt of a character after the break is detected. In order to receive more characters, the SCI must be reset by toggling the SW RESET bit or by a system reset. |
|     |          | 0     | No break condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |          | 1     | Break condition occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4   | FE       |       | SCI framing-error flag. The SCI sets this bit when an expected stop bit is not found. Only the first stop bit is checked. The missing stop bit indicates that synchronization with the start bit has been lost and that the character is incorrectly framed. The FE bit is reset by a clearing of the SW RESET bit or by a system reset.                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | 0     | No framing error detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |          | 1     | Framing error detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3   | OE       |       | SCI overrun-error flag. The SCI sets this bit when a character is transferred into registers SCIRXEMU and SCIRXBUF before the previous character is fully read by the CPU or DMAC. The previous character is overwritten and lost. The OE flag bit is reset by an active SW RESET or by a system reset.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |          | 0     | No overrun error detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |          | 1     | Overrun error detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2   | PE       |       | SCI parity-error flag. This flag bit is set when a character is received with a mismatch between the number of 1s and its parity bit. The address bit is included in the calculation. If parity generation and detection is not enabled, the PE flag is disabled and read as 0. The PE bit is reset by an active SW RESET or a system reset.!                                                                                                                                                                                                                                                                                                                                                                                      |
|     |          | 0     | No parity error or parity is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|     |          | 1     | Parity error is detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1   | RXWAKE   |       | Receiver wake-up-detect flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |          | 0     | No detection of a receiver wake-up condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |          | 1     | A value of 1 in this bit indicates detection of a receiver wake-up condition. In the address-bit multiprocessor mode (SCICCR.3 = 1), RXWAKE reflects the value of the address bit for the character contained in SCIRXBUF. In the idle-line multiprocessor mode, RXWAKE is set if the SCIRXD data line is detected as idle. RXWAKE is a read-only flag, cleared by one of the following:                                                                                                                                                                                                                                                                                                                                           |
|     |          |       | The transfer of the first byte after the address byte to SCIRXBUF (only in non-FIFO mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |          |       | The reading of SCIRXBUF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |          |       | An active SW RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |          |       | A system reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0   | Reserved |       | Reads return zero; writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Table 11-12. SCI Receiver Status Register (SCIRXST) Field Descriptions





### 11.2.7 Receiver Data Buffer Registers (SCIRXEMU, SCIRXBUF)

Received data is transferred from RXSHF to SCIRXEMU and SCIRXBUF. When the transfer is complete, the RXRDY flag (bit SCIRXST.6) is set, indicating that the received data is ready to be read. Both registers contain the same data; they have separate addresses but are not physically separate buffers. The only difference is that reading SCIRXEMU does not clear the RXRDY flag; however, reading SCIRXBUF clears the flag.

### 11.2.7.1 Emulation Data Buffer (SCIRXEMU)

Normal SCI data-receive operations read the data received from the SCIRXBUF register. The SCIRXEMU register is used principally by the emulator (EMU) because it can continuously read the data received for screen updates without clearing the RXRDY flag. SCIRXEMU is cleared by a system reset.

This is the register that should be used in an emulator watch window to view the contents of the SCIRXBUF register.

SCIRXEMU is not physically implemented; it is just a different address location to access the SCIRXBUF register without clearing the RXRDY flag.

| rigure risto. Emulation bata banci register (oontxeliio) - Address room |        |        |        |        |        |        |        |  |  |  |
|-------------------------------------------------------------------------|--------|--------|--------|--------|--------|--------|--------|--|--|--|
| 7                                                                       | 6      | 5      | 4      | 3      | 2      | 1      | 0      |  |  |  |
| ERXDT7                                                                  | ERXDT6 | ERXDT5 | ERXDT4 | ERXDT3 | ERXDT2 | ERXDT1 | ERXDT0 |  |  |  |
| R-0                                                                     | R-0    | R-0    | R-0    | R-0    | R-0    | R-0    | R-0    |  |  |  |

### Figure 11-18. Emulation Data Buffer Register (SCIRXEMU) — Address 7056h

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### 11.2.7.2 Receiver Data Buffer (SCIRXBUF)

When the current data received is shifted from RXSHF to the receiver buffer, flag bit RXRDY is set and the data is ready to be read. If the RX/BK INT ENA bit (SCICTL2.1) is set, this shift also causes an interrupt. When SCIRXBUF is read, the RXRDY flag is reset. SCIRXBUF is cleared by a system reset.

#### Figure 11-19. SCI Receive Data Buffer Register (SCIRXBUF) — Address 7057h

| 15                     | 14                     | 13    |          |       |       |       | 8     |  |  |  |
|------------------------|------------------------|-------|----------|-------|-------|-------|-------|--|--|--|
| SCIFFFE <sup>(1)</sup> | SCIFFPE <sup>(1)</sup> |       | Reserved |       |       |       |       |  |  |  |
| R-0                    | R-0                    |       | R-0      |       |       |       |       |  |  |  |
| 7                      | 6                      | 5     | 4        | 3     | 2     | 1     | 0     |  |  |  |
| RXDT7                  | RXDT6                  | RXDT5 | RXDT4    | RXDT3 | RXDT2 | RXDT1 | RXDT0 |  |  |  |
| R-0                    | R-0                    | R-0   | R-0      | R-0   | R-0   | R-0   | R-0   |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

<sup>(1)</sup> Applicable only if the FIFO is enabled.



| Bit  | Field      | Value | Description                                                                                                                            |
|------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------|
| 15   | 15 SCIFFFE |       | SCIFFFE. SCI FIFO Framing error flag bit (applicable only if the FIFO is enabled)                                                      |
|      |            | 0     | No frame error occurred while receiving the character, in bits 7–0. This bit is associated with the character on the top of the FIFO.  |
|      |            | 1     | A frame error occurred while receiving the character in bits 7–0. This bit is associated with the character on the top of the FIFO.    |
| 14   | SCIFFPE    |       | SCIFFPE. SCI FIFO parity error flag bit (applicable only if the FIFO is enabled)                                                       |
|      |            | 0     | No parity error occurred while receiving the character, in bits 7–0. This bit is associated with the character on the top of the FIFO. |
|      |            | 1     | A parity error occurred while receiving the character in bits 7–0. This bit is associated with the character on the top of the FIFO.   |
| 13-8 | Reserved   |       |                                                                                                                                        |
| 7-0  | RXDT7-0    |       | Receive Character bits                                                                                                                 |

### Table 11-13. SCI Receive Data Buffer Register (SCIRXBUF) Field Descriptions

### 11.2.8 SCI Transmit Data Buffer Register (SCITXBUF)

Data bits to be transmitted are written to SCITXBUF. These bits must be rightjustified because the leftmost bits are ignored for characters less than eight bits long. The transfer of data from this register to the TXSHF transmitter shift register sets the TXRDY flag (SCICTL2.7), indicating that SCITXBUF is ready to receive another set of data. If bit TX INT ENA (SCICTL2.0) is set, this data transfer also causes an interrupt.

### Figure 11-20. Transmit Data Buffer Register (SCITXBUF) — Address 7059h

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| TXDT7 | TXDT6 | TXDT5 | TXDT4 | TXDT3 | TXDT2 | TXDT1 | TXDT0 |
| R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### 11.2.9 SCI FIFO Registers (SCIFFTX, SCIFFRX, SCIFFCT)

|              | Figure 11-21. SCI FIFO Transmit (SCIFFTX) Register — Address 705An |              |         |         |         |         |         |  |  |  |  |  |  |
|--------------|--------------------------------------------------------------------|--------------|---------|---------|---------|---------|---------|--|--|--|--|--|--|
| 15           | 14                                                                 | 13           | 12      | 11      | 10      | 9       | 8       |  |  |  |  |  |  |
| SCIRST       | SCIFFENA                                                           | TXFIFO Reset | TXFFST4 | TXFFST3 | TXFFST2 | TXFFST1 | TXFFST0 |  |  |  |  |  |  |
| R/W-1        | R/W-0                                                              | R/W-1        | R-0     | R-0     | R-0     | R-0     | R-0     |  |  |  |  |  |  |
| 7            | 6                                                                  | 5            | 4       | 3       | 2       | 1       | 0       |  |  |  |  |  |  |
| TXFFINT Flag | TXFFINT CLR                                                        | TXFFIENA     | TXFFIL4 | TXFFIL3 | TXFFIL2 | TXFFIL1 | TXFFIL0 |  |  |  |  |  |  |
| R-0          | W-0                                                                | R/W-0        | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   |  |  |  |  |  |  |

### Figure 11-21. SCI FIFO Transmit (SCIFFTX) Register — Address 705Ah

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 11-14. Field Descriptions

| Bit | Field        | Value | Description                                                                                                      |
|-----|--------------|-------|------------------------------------------------------------------------------------------------------------------|
| 15  | SCIRST       |       | SCI Reset                                                                                                        |
|     |              | 0     | Write 0 to reset the SCI transmit and receive channels. SCI FIFO register configuration bits will be left as is. |
|     |              | 1     | SCI FIFO can resume transmit or receive. SCIRST should be 1 even for Autobaud logic to work.                     |
| 14  | SCIFFENA     |       | SCI FIFO enable                                                                                                  |
|     |              | 0     | SCI FIFO enhancements are disabled                                                                               |
|     |              | 1     | SCI FIFO enhancements are enabled                                                                                |
| 13  | TXFIFO Reset |       | Transmit FIFO reset                                                                                              |
|     |              | 0     | Reset the FIFO pointer to zero and hold in reset                                                                 |
|     |              | 1     | Re-enable transmit FIFO operation                                                                                |



 Table 11-14. Field Descriptions (continued)

| Bit  | Field        | Value | Description                                                                                                                                                                                                                                                                                                        |
|------|--------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12-8 | TXFFST4-0    | 00000 | Transmit FIFO is empty.                                                                                                                                                                                                                                                                                            |
|      |              | 00001 | Transmit FIFO has 1 words                                                                                                                                                                                                                                                                                          |
|      |              | 00010 | Transmit FIFO has 2 words                                                                                                                                                                                                                                                                                          |
|      |              | 00011 | Transmit FIFO has 3 words                                                                                                                                                                                                                                                                                          |
|      |              | 00100 | Transmit FIFO has 4 words                                                                                                                                                                                                                                                                                          |
| 7    | TXFFINT Flag |       | Transmit FIFO interrupt                                                                                                                                                                                                                                                                                            |
|      |              | 0     | TXFIFO interrupt has not occurred, read-only bit                                                                                                                                                                                                                                                                   |
|      |              | 1     | TXFIFO interrupt has occurred, read-only bit                                                                                                                                                                                                                                                                       |
| 6    | TXFFINT CLR  |       | Transmit FIFO clear                                                                                                                                                                                                                                                                                                |
|      |              | 0     | Write 0 has no effect on TXFIFINT flag bit, Bit reads back a zero                                                                                                                                                                                                                                                  |
|      |              | 1     | Write 1 to clear TXFFINT flag in bit 7                                                                                                                                                                                                                                                                             |
| 5    | TXFFIENA     |       | Transmit FIFO interrrupt enable                                                                                                                                                                                                                                                                                    |
|      |              | 0     | TX FIFO interrupt based on TXFFIVL match (less than or equal to) is disabled                                                                                                                                                                                                                                       |
|      |              | 1     | TX FIFO interrupt based on TXFFIVL match (less than or equal to) is enabled.                                                                                                                                                                                                                                       |
| 4-0  | TXFFIL4-0    |       | TXFFIL4-0 Transmit FIFO interrupt level bits. Transmit FIFO will generate interrupt when the FIFO status bits (TXFFST4-0) and FIFO level bits (TXFFIL4-0) match (less than or equal to). Because the SCI has a 4-level transmit FIFO, these bits cannot be configured for an interrupt of more than 4 FIFO levels. |
|      |              |       | Default value should be 0x00000.                                                                                                                                                                                                                                                                                   |

### Figure 11-22. SCI FIFO Receive (SCIFFRX) Register — Address 705Bh

| 15                | 14               | 13                  | 12           | 11           | 10           | 9            | 8            |
|-------------------|------------------|---------------------|--------------|--------------|--------------|--------------|--------------|
| RXFFOVF           | RXFFOVR CLR      | <b>RXFIFO</b> Reset | RXFIFST4     | RXFFST3      | RXFFST2      | RXFFST1      | RXFFST0      |
| R-0               | W-0              | R/W-1               | R-0          | R-0          | R-0          | R-0          | R-0          |
|                   |                  |                     |              |              |              |              |              |
| 7                 | 6                | 5                   | 4            | 3            | 2            | 1            | 0            |
| 7<br>RXFFINT Flag | 6<br>RXFFINT CLR | 5<br>RXFFIENA       | 4<br>RXFFIL4 | 3<br>RXFFIL3 | 2<br>RXFFIL2 | 1<br>RXFFIL1 | 0<br>RXFFIL0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 11-15. SCI FIFO Receive (SCIFFRX) Register Field Descriptions

| Bit  | Field        | Value | Description                                                                                                                                                                                                     |
|------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | RXFFOVF      |       | Receive FIFO overflow. This will function as flag, but cannot generate interrupt by itself. This condition will occur while receive interrupt is active. Receive interrupts should service this flag condition. |
|      |              | 0     | Receive FIFO has not overflowed, read-only bit                                                                                                                                                                  |
|      |              | 1     | Receive FIFO has overflowed, read-only bit. More than 16 words have been received in to the FIFO, and the first received word is lost                                                                           |
| 14   | RXFFOVR CLR  |       | RXFFOVF clear                                                                                                                                                                                                   |
|      |              | 0     | Write 0 has no effect on RXFFOVF flag bit, Bit reads back a zero                                                                                                                                                |
|      |              | 1     | Write 1 to clear RXFFOVF flag in bit 15                                                                                                                                                                         |
| 13   | RXFIFO Reset |       | Receive FIFO reset                                                                                                                                                                                              |
|      |              | 0     | Write 0 to reset the FIFO pointer to zero, and hold in reset.                                                                                                                                                   |
|      |              | 1     | Re-enable receive FIFO operation                                                                                                                                                                                |
| 12-8 | RXFFST4-0    | 00000 | Receive FIFO is empty                                                                                                                                                                                           |
|      |              | 00001 | Receive FIFO has 1 word                                                                                                                                                                                         |
|      |              | 00010 | Receive FIFO has 2 words                                                                                                                                                                                        |
|      |              | 00011 | Receive FIFO has 3 words                                                                                                                                                                                        |
|      |              | 00100 | Receive FIFO has 4 words, the maximum allowed.                                                                                                                                                                  |



| Bit | Field       | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|-----|-------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7   | RXFFINT     |       | Receive FIFO interrupt                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|     |             | 0     | RXFIFO interrupt has not occurred, read-only bit                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|     |             | 1     | RXFIFO interrupt has occurred, read-only bit                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 6   | RXFFINT CLR |       | Receive FIFO interrupt clear                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|     |             | 0     | Write 0 has no effect on RXFIFINT flag bit. Bit reads back a zero.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|     |             | 1     | Write 1 to clear RXFFINT flag in bit 7                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 5   | RXFFIENA    |       | Receive FIFO interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|     |             | 0     | RX FIFO interrupt based on RXFFIVL match (less than or equal to) will be disabled                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|     |             | 1     | RX FIFO interrupt based on RXFFIVL match (less than or equal to) will be enabled.                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| 4-0 | RXFFIL4-0   |       | Receive FIFO interrupt level bits                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|     |             | 11111 | Receive FIFO generates interrupt when the FIFO status bits (RXFFST4-0) and FIFO level bits (RXFFIL4-0) match (i.e., are greater than or equal to). Default value of these bits after reset – 11111. This will avoid frequent interrupts, after reset, as the receive FIFO will be empty most of the time. Because the SCI has a 4-level receive FIFO, these bits cannot be configured for an interrupt of more than 4 FIFO levels. |  |  |  |

### Table 11-15. SCI FIFO Receive (SCIFFRX) Register Field Descriptions (continued)

Figure 11-23. SCI FIFO Control (SCIFFCT) Register — Address 705Ch

| 15       | 14       | 13       | 12       |          |          |          | 8        |
|----------|----------|----------|----------|----------|----------|----------|----------|
| ABD      | ABD CLR  | CDC      |          |          | Reserved |          |          |
| R-0      | W-0      | R/W-0    |          |          | R-0      |          |          |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| FFTXDLY7 | FFTXDLY6 | FFTXDLY5 | FFTXDLY4 | FFTXDLY3 | FFTXDLY2 | FFTXDLY1 | FFTXDLY0 |
| R/W-0    |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 11-16. SCI FIFO Control (SCIFFCT) Register Field Descriptions

| Bit  | Field    | Value | Description                                                                                                |
|------|----------|-------|------------------------------------------------------------------------------------------------------------|
| 15   | ABD      |       | Auto-baud detect (ABD) bit.                                                                                |
|      |          | 0     | Auto-baud detection is not complete. "A", "a" character has not been received successfully.                |
|      |          | 1     | Auto-baud hardware has detected "A" or "a" character on the SCI receive register. Auto-detect is complete. |
| 14   | ABD CLR  |       | ABD-clear bit                                                                                              |
|      |          | 0     | Write 0 has no effect on ABD flag bit. Bit reads back a zero.                                              |
|      |          | 1     | Write 1 to clear ABD flag in bit 15.                                                                       |
| 13   | CDC      |       | CDC calibrate A-detect bit                                                                                 |
|      |          | 0     | Disables auto-baud alignment                                                                               |
|      |          | 1     | Enables auto-baud alignment                                                                                |
| 12-8 | Reserved |       | Reserved                                                                                                   |

| www.ti | .com |
|--------|------|
|        |      |

| Bit | Field          | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | 7–0 FFTXDLY7–0 |       | FIFO transfer delay. These bits define the delay between every transfer from FIFO transmit buffer to transmit shift register. The delay is defined in the number of SCI serial baud clock cycles. The 8 bit register could define a minimum delay of 0 baud clock cycles and a maximum of 256 baud clock cycles                                                                                                                              |
|     |                |       | In FIFO mode, the buffer (TXBUF) between the shift register and the FIFO should be filled only after the shift register has completed shifting of the last bit. This is required to pass on the delay between transfers to the data stream. In FIFO mode, TXBUF should not be treated as one additional level of buffer. The delayed transmit feature will help to create an auto-flow scheme without RTS/CTS controls as in standard UARTS. |
|     |                |       | When SCI is configured for one stop-bit, delay introduced by FFTXDLY between one frame and the next frame is equal to number of baud clock cycles that FFTXDLY is set to.                                                                                                                                                                                                                                                                    |
|     |                |       | When SCI is configured for two stop-bits, delay introduced by FFTXDLY between one frame and the next frame is equal to number of baud clock cycles that FFTXDLY is set to minus 1.                                                                                                                                                                                                                                                           |

### Table 11-16. SCI FIFO Control (SCIFFCT) Register Field Descriptions (continued)



### 11.2.10 Priority Control Register (SCIPRI)

### Figure 11-24. SCI Priority Control Register (SCIPRI) — Address 705Fh

| 7 | _        | 5 | 4        | 3        | 2 |          | 0 |
|---|----------|---|----------|----------|---|----------|---|
|   | Reserved |   | SCI SOFT | SCI FREE |   | Reserved |   |
|   | R-0      |   | R/W-0    | R/W-0    |   | R-0      |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 11-17. Field Descriptions

| Bit | Field         | Value | Description                                                                                                                                                                                                                                                                                                                              |  |
|-----|---------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7-5 | Reserved      |       | Reads return zero; writes have no effect.                                                                                                                                                                                                                                                                                                |  |
| 4-3 | SOFT and FREE |       | These bits determine what occurs when an emulation suspend event occurs (for example, when the debugger hits a breakpoint). The peripheral can continue whatever it is doing (free-run mode), or if in stop mode, it can either stop immediately or stop when the current operation (the current receive/transmit sequence) is complete. |  |
|     |               | 00    | Immediate stop on suspend                                                                                                                                                                                                                                                                                                                |  |
|     |               | 10    | Complete current receive/transmit sequence before stopping                                                                                                                                                                                                                                                                               |  |
|     |               | x1    | Free run. Continues SCI operation regardless of suspend                                                                                                                                                                                                                                                                                  |  |
| 2-0 | Reserved      |       | Reads return zero; writes have no effect.                                                                                                                                                                                                                                                                                                |  |



Page

# Enhanced Controller Area Network (eCAN)

The enhanced Controller Area Network (eCAN) module is a full-CAN controller and is compatible with the CAN 2.0B standard (active). It uses established protocol to communicate serially with other controllers in electrically noisy environments. With 32 fully configurable mailboxes and time-stamping feature, the eCAN module provides a versatile and robust serial communication interface.

The eCAN module described in this reference guide is a Type 2 eCAN. Refer to theTMS320x28xx, 28xxx DSP Peripheral Reference Guide (<u>SPRU566</u>) for a list of other devices with a eCAN module of the same type, to determine the differences between types, and for a list of device-specific differences within a type. For a given CAN module, the same address space is used for the module registers in all 28xx /28xxx devices.

#### Topic

| 12.1 | CAN Overview               | 747 |
|------|----------------------------|-----|
| 12.2 | The CAN Network and Module | 749 |
| 12.3 | eCAN Controller Overview   | 750 |
| 12.4 | Message Objects            | 755 |
| 12.5 | Message Mailbox            | 755 |
| 12.6 | eCAN Registers             | 758 |
| 12.7 | eCAN Configuration         | 799 |



### 12.1 CAN Overview

Figure 12-1 shows the major blocks of the eCAN and the interface circuits.

### 12.1.1 Features

The eCAN module has the following features:

- Fully compliant with CAN protocol, version 2.0B
- Supports data rates up to 1 Mbps
- Thirty-two mailboxes, each with the following properties:
  - Configurable as receive or transmit
  - Configurable with standard or extended identifier
  - Has a programmable acceptance filter mask
  - Supports data and remote frame
  - Supports 0 to 8 bytes of data
  - Uses a 32-bit time stamp on received and transmitted message
  - Protects against reception of new message
  - Allows dynamically programmable priority of transmit message
  - Employs a programmable interrupt scheme with two interrupt levels
  - Employs a programmable interrupt on transmission or reception time-out
- Low-power mode
- Programmable wake-up on bus activity
- Automatic reply to a remote request message
- Automatic retransmission of a frame in case of loss of arbitration or error
- 32-bit time-stamp counter synchronized by a specific message (communication in conjunction with mailbox 16)
- Self-test mode
  - Operates in a loopback mode receiving its own message. A "dummy" acknowledge is provided, thereby eliminating the need for another node to provide the acknowledge bit.



CAN Overview

#### 12.1.2 Block Diagram



Figure 12-1. eCAN Block Diagram and Interface Circuit

A The communication buffers are transparent to the user and are not accessible by user code.

### 12.1.3 eCAN Compatibility With Other TI CAN Modules

The eCAN module is identical to the "High-end CAN Controller (HECC)" used in the TMS470<sup>™</sup> series microcontrollers from Texas Instruments with some minor changes. The eCAN module features several enhancements (such as increased number of mailboxes with individual acceptance masks, time stamping, etc.) over the CAN module featured in 240x<sup>™</sup> series of DSPs. For this reason, code written for 240x CAN modules cannot be directly ported to eCAN. However, eCAN follows the same register bit-layout structure and bit functionality as that of 240x CAN (for registers that exist in both devices) that is, many registers and bits perform exactly identical functions across these two platforms. This makes code migration a relatively easy task, more so with code written in C language.

### **12.2 The CAN Network and Module**

The controller area network (CAN) uses a serial multimaster communication protocol that efficiently supports distributed real-time control, with a very high level of security, and a communication rate of up to 1 Mbps. The CAN bus is ideal for applications operating in noisy and harsh environments, such as in the automotive and other industrial fields that require reliable communication.

Prioritized messages of up to eight bytes in data length can be sent on a multimaster serial bus using an arbitration protocol and an error-detection mechanism for a high level of data integrity.

### 12.2.1 CAN Protocol Overview

The CAN protocol supports four different frame types for communication:

- Data frames that carry data from a transmitter node to the receiver nodes
- Remote frames that are transmitted by a node to request the transmission of a data frame with the same identifier
- Error frames that are transmitted by any node on a bus-error detection
- Overload frames that provide an extra delay between the preceding and the succeeding data frames or remote frames.

In addition, CAN specification version 2.0B defines two different formats that differ in the length of the identifier field: standard frames with an 11-bit identifier and extended frames with 29-bit identifier.

CAN standard data frames contain from 44 to 108 bits and CAN extended data frames contain 64 to 128 bits. Furthermore, up to 23 stuff bits can be inserted in a standard data frame, and up to 28 stuff bits in an extended data frame, depending on the data-stream coding. The overall maximum data frame length is then 131 bits for a standard frame and 156 bits for an extended frame.

The bit fields that make up standard/extended data frames, along with their position as shown in Figure 12-2 include the following:

- Start of frame
- Arbitration field containing the identifier and the type of message being sent
- · Control field indicating the number of bytes being transmitted.
- Up to 8 bytes of data
- Cyclic redundancy check (CRC)
- Acknowledgment
- End-of-frame bits



Figure 12-2. CAN Data Frame

Note: Unless otherwise noted, numbers are amount of bits in field.

The eCAN controller provides the CPU with full functionality of the CAN protocol, version 2.0B. The CAN controller minimizes the CPU's load in communication overhead and enhances the CAN standard by providing additional features.

The architecture of eCAN module, shown in Figure 12-3, is composed of a CAN protocol kernel (CPK) and a message controller.



Figure 12-3. Architecture of the eCAN Module

A The receive and transmit buffers are transparent to the user and are not accessible by user code.

Two functions of the CPK are to decode all messages received on the CAN bus according to the CAN protocol and to transfer these messages into a receive buffer. Another CPK function is to transmit messages on the CAN bus according to the CAN protocol.

The message controller of a CAN controller is responsible for determining if any message received by the CPK must be preserved for the CPU use or be discarded. At the initialization phase, the CPU specifies to the message controller all message identifiers used by the application. The message controller is also responsible for sending the next message to transmit to the CPK according to the message's priority.

### 12.3 eCAN Controller Overview

The eCAN is a CAN controller with an internal 32-bit architecture.

The eCAN module consists of:

- The CAN protocol kernel (CPK)
- The message controller comprising:
  - The memory management unit (MMU), including the CPU interface and the receive control unit (acceptance filtering), and the timer management unit
  - Mailbox RAM enabling the storage of 32 messages
  - Control and status registers

After the reception of a valid message by the CPK, the receive control unit of the message controller determines if the received message must be stored into one of the 32 message objects of the mailbox RAM. The receive control unit checks the state, the identifier, and the mask of all message objects to determine the appropriate mailbox location. The received message is stored into the first mailbox passing the acceptance filtering. If the receive control unit could not find any mailbox to store the received message, the message is discarded.



A message is composed of an 11- or 29-bit identifier, a control field, and up to 8 bytes of data.

When a message must be transmitted, the message controller transfers the message into the transmit buffer of the CPK in order to start the message transmission at the next bus-idle state. When more than one message must be transmitted, the message with the highest priority that is ready to be transmitted is transferred into the CPK by the message controller. If two mailboxes have the same priority, then the mailbox with the higher number is transmitted first.

The timer management unit comprises a time-stamp counter and apposes a time stamp to all messages received or transmitted. It generates an interrupt when a message has not been received or transmitted during an allowed period of time (time-out). The time-stamping feature is available in eCAN mode only.

To initiate a data transfer, the transmission request bit (TRS.n) has to be set in the corresponding control register. The entire transmission procedure and possible error handling are then performed without any CPU involvement. If a mailbox has been configured to receive messages, the CPU easily reads its data registers using CPU read instructions. The mailbox may be configured to interrupt the CPU after every successful message transmission or reception.

### 12.3.1 Standard CAN Controller (SCC) Mode

The SCC Mode is a reduced functionality mode of the eCAN. Only 16 mailboxes (0 through 15) are available in this mode. The time stamping feature is not available and the number of acceptance masks available is reduced. This mode is selected by default. The SCC mode or the full featured eCAN mode is selected using the SCB bit (CANMC.13).



#### 12.3.2 Memory Map

The eCAN module has two different address segments mapped in the memory. The first segment is used to access the control registers, the status registers, the acceptance masks, the time stamp, and the time-out of the message objects. The access to the control and status registers is limited to 32-bit wide accesses. The local acceptance masks, the time stamp registers, and the time-out registers can be accessed 8-bit, 16-bit and 32-bit wide. The second address segment is used to access the mailboxes. This memory range can be accessed 8-bit, 16-bit and 32-bit wide. Each of these two memory blocks, shown in Figure 12-4, uses 512 bytes of address space.

The message storage is implemented by a RAM that can be addressed by the CAN controller or the CPU. The CPU controls the CAN controller by modifying the various mailboxes in the RAM or the additional registers. The contents of the various storage elements are used to perform the functions of the acceptance filtering, message transmission, and interrupt handling.

The mailbox module in the eCAN provides 32 message mailboxes of 8-byte data length, a 29-bit identifier, and several control bits. Each mailbox can be configured as either transmit or receive. In the eCAN mode, each mailbox has its individual acceptance mask.

```
NOTE: LAMn, MOTSn and MOTOn registers and mailboxes not used in an application (disabled in the CANME register) may be used as general-purpose data memory by the CPU.
```

#### 12.3.2.1 32-bit Access to Control and Status Registers

As indicated in Section 12.3.2, only 32-bit accesses are allowed to the Control and Status registers. 16-bit access to these registers could potentially corrupt the register contents or return false data. The DSP header files released by TI employs a shadow register structure that aids in 32-bit access. Following are a few examples of how the shadow register structure may be employed to perform 32-bit reads/writes:

#### Example 12-1. Modifying a bit in a register

ECanaShadow.CANTIOC.all = ECanaRegs.CANTIOC.all; // Step 1 ECanaShadow.CANTIOC.bit.TXFUNC = 1; // Step 2 ECanaRegs.CANTIOC.all = ECanaShadow.CANTIOC.all; // Step 3

Step 1: Perform a 32-bit read to copy the entire register to its shadow

Step 2: Modify the needed bit(s) in the shadow

Step 3: Perform a 32-bit write to copy the modified shadow to the original register.

**NOTE:** Some bits like TAn and RMPn are cleared by writing a 1 to it. Care should be taken not to clear bits inadvertently.

#### Example 12-2. Checking the value of a bit in a register

```
do { ECanaShadow.CANTA.all = ECanaRegs.CANTA.all; }while(ECanaShadow.CANTA.bit.TA25 == 0); // Wait
for TA5 bit to be set..
```

In the above example, the value of TA25 bit needs to be checked. This is done by first copying the entire CANTA register to its shadow (using a 32-bit read) and then checking the relevant bit, repeating this operation until that condition is satisfied. TA25 bit should NOT be checked with the following statement:

while(ECanaRegs.CANTA.bit.TA25 == 0);



### Figure 12-4. eCAN-A Memory Map

eCAN-A Control and Status Registers

|       | eCAN-A Registers (512 Bytes)      |
|-------|-----------------------------------|
| 6000h | Control and Status Registers      |
| 603Fh |                                   |
| 6040h | Local Acceptance Masks (LAM)      |
| 607Fh | (32 × 32–Bit RAM)                 |
| 6080h | Message Object Time Stamps (MOTS) |
| 60BFh | (32 × 32–Bit RAM)                 |
| 60C0h | Message Object Time-Out (MOTO)    |
| 60FFh | (32 × 32–Bit RAM)                 |
|       |                                   |

#### eCAN-A Mailbox RAM (512 Bytes)

| 6100h-6107h | Mailbox 0  |
|-------------|------------|
| 6108h–610Fh | Mailbox 1  |
| 6110h–6117h | Mailbox 2  |
| 6118h–611Fh | Mailbox 3  |
| 6120h-6127h | Mailbox 4  |
|             |            |
|             |            |
|             |            |
| 61E0h-61E7h | Mailbox 28 |
| 61E8h-61EFh | Mailbox 29 |
| 61F0h-61F7h | Mailbox 30 |
| 61F8h-61FFh | Mailbox 31 |
|             |            |
|             |            |

| / | Mailbox Enable – CANME                |
|---|---------------------------------------|
|   | Mailbox Direction – CANMD             |
|   | Transmission Request Set – CANTRS     |
|   | Transmission Request Reset – CANTRR   |
|   | Transmission Acknowledge – CANTA      |
|   | Abort Acknowledge – CANAA             |
|   | Received Message Pending – CANRMP     |
|   | Received Message Lost – CANRML        |
|   | Remote Frame Pending – CANRFP         |
|   | Global Acceptance Mask – CANGAM       |
|   | Master Control – CANMC                |
|   | Bit–Timing Configuration – CANBTC     |
|   | Error and Status – CANES              |
|   | Transmit Error Counter – CANTEC       |
|   | Receive Error Counter – CANREC        |
|   | Global Interrupt Flag 0 – CANGIF0     |
|   | Global Interrupt Mask – CANGIM        |
|   | Global Interrupt Flag 1 – CANGIF1     |
|   | Mailbox Interrupt Mask – CANMIM       |
|   | Mailbox Interrupt Level – CANMIL      |
|   | Overwrite Protection Control – CANOPC |
|   | TX I/O Control – CANTIOC              |
|   | RX I/O Control – CANRIOC              |
|   | Time-Stamp Counter - CANTSC           |
|   | Time–Out Control – CANTOC             |
|   | Time–Out Status – CANTOS              |
|   | Reserved                              |

#### Message Mailbox (16 Bytes)

| ````        |                                      |
|-------------|--------------------------------------|
| 61E8h-61E9h | Message Identifier – MSGID (32 bits) |
| 61EAh–61EBh | Message Control – MSGCTRL (32 bits)  |
| 61ECh-61EDh | Message Data Low – CANMDL (4 bytes)  |
| 61EEh-61EFh | Message Data High – CANMDH (4 bytes) |

### 12.3.3 eCAN Control and Status Registers

The eCAN registers listed in Table 12-1 are used by the CPU to configure and control the CAN controller and the message objects.

|                   |         | i dibito i |                                           |
|-------------------|---------|------------|-------------------------------------------|
| REGISTER NAME (1) | ECAN-A  | SIZE       | DESCRIPTION                               |
|                   | ADDRESS | (x32)      |                                           |
| CANME             | 0x6000  | 1          | Mailbox enable                            |
| CANMD             | 0x6002  | 1          | Mailbox direction                         |
| CANTRS            | 0x6004  | 1          | Transmit request set                      |
| CANTRR            | 0x6006  | 1          | Transmit request reset                    |
| CANTA             | 0x6008  | 1          | Transmission acknowledge                  |
| CANAA             | 0x600A  | 1          | Abort acknowledge                         |
| CANRMP            | 0x600C  | 1          | Receive message pending                   |
| CANRML            | 0x600E  | 1          | Receive message lost                      |
| CANRFP            | 0x6010  | 1          | Remote frame pending                      |
| CANGAM            | 0x6012  | 1          | Global acceptance mask                    |
| CANMC             | 0x6014  | 1          | Master control                            |
| CANBTC            | 0x6016  | 1          | Bit-timing configuration                  |
| CANES             | 0x6018  | 1          | Error and status                          |
| CANTEC            | 0x601A  | 1          | Transmit error counter                    |
| CANREC            | 0x601C  | 1          | Receive error counter                     |
| CANGIF0           | 0x601E  | 1          | Global interrupt flag 0                   |
| CANGIM            | 0x6020  | 1          | Global interrupt mask                     |
| CANGIF1           | 0x6022  | 1          | Global interrupt flag 1                   |
| CANMIM            | 0x6024  | 1          | Mailbox interrupt mask                    |
| CANMIL            | 0x6026  | 1          | Mailbox interrupt level                   |
| CANOPC            | 0x6028  | 1          | Overwrite protection control              |
| CANTIOC           | 0x602A  | 1          | TX I/O control                            |
| CANRIOC           | 0x602C  | 1          | RX I/O control                            |
| CANTSC            | 0x602E  | 1          | Time stamp counter (Reserved in SCC mode) |
| CANTOC            | 0x6030  | 1          | Time-out control (Reserved in SCC mode)   |
| CANTOS            | 0x6032  | 1          | Time-out status (Reserved in SCC mode)    |

| Table | 12-1. | Register | Map |
|-------|-------|----------|-----|
|       |       |          |     |

<sup>(1)</sup> These registers are mapped to Peripheral Frame 1.

**NOTE:** Only 32-bit accesses are allowed to the control and status registers. This restriction does not apply to the mailbox RAM area. See Section 12.3.2.1 for more information.



### 12.4 Message Objects

The eCAN module has 32 different message objects (mailboxes).

Each message object can be configured to either transmit or receive. Each message object has its individual acceptance mask.

A message object consists of a message mailbox with:

- The 29-bit message identifier
- The message control register
- 8 bytes of message data
- A 29-bit acceptance mask
- A 32-bit time stamp
- A 32-bit time-out value

Furthermore, corresponding control and status bits located in the registers allow control of the message objects.

### 12.5 Message Mailbox

The message mailboxes are the RAM area where the CAN messages are actually stored after they are received or before they are transmitted.

The CPU may use the RAM area of the message mailboxes that are not used for storing messages as normal memory.

Each mailbox contains:

- The message identifier
  - 29 bits for extended identifier
  - 11 bits for standard identifier
- The identifier extension bit, IDE (MSGID.31)
- The acceptance mask enable bit, AME (MSGID.30)
- The auto answer mode bit, AAM (MSGID.29)
- The transmit priority level, TPL (MSGCTRL.12-8)
- The remote transmission request bit, RTR (MSGCTRL.4)
- The data length code, DLC (MSGCTRL.3-0)
- Up to eight bytes for the data field

Each of the mailboxes can be configured as one of four message object types. Transmit and receive message objects are used for data exchange between one sender and multiple receivers (1 to n communication link), whereas request and reply message objects are used to set up a one-to-one communication link. Table 12-2 lists the mailbox RAM layout.

| Message Maill |
|---------------|
|---------------|

### Table 12-2. eCAN-A Mailbox RAM Layout

www.ti.com

| Mailbox | MSGID<br>MSGIDL-MSGIDH | MSGCTRL<br>MSGCTRL-Rsvd | CANMDL<br>CANMDL_L- CANMDL_H | CANMDH<br>CANMDH_L- CANMDH_H |
|---------|------------------------|-------------------------|------------------------------|------------------------------|
| 0       | 6100-6101h             | 6102-6103h              | 6104-6105h                   | 6106-6107h                   |
| 1       | 6108-6109h             | 610A-610Bh              | 610C-610Dh                   | 610E-610Fh                   |
| 2       | 6110 - 6111h           | 6112-6113h              | 6114-6115h                   | 6116-6117h                   |
| 3       | 6118-6119h             | 611A-611Bh              | 611C-611Dh                   | 611E-611Fh                   |
| 4       | 6120-6121h             | 6122-6123h              | 6124-6125h                   | 6126-6127h                   |
| 5       | 6128-6129h             | 612A-612Bh              | 612C-612Dh                   | 612E-612Fh                   |
| 6       | 6130-6131h             | 6132-6133h              | 6134-6135h                   | 6136-6137h                   |
| 7       | 6138-6139h             | 613A-613Bh              | 613C-613Dh                   | 613E-613Fh                   |
| 8       | 6140-6141h             | 6142-6143h              | 6144-6145h                   | 6146-6147h                   |
| 9       | 6148-6149h             | 614A-614Bh              | 614C-614Dh                   | 614E-614Fh                   |
| 10      | 6150-6151h             | 6152-6153h              | 6154-6155h                   | 6156-6157h                   |
| 11      | 6158-6159h             | 615A-615Bh              | 615C-615Dh                   | 615E-615Fh                   |
| 12      | 6160-6161h             | 6162-6163h              | 6164-6165h                   | 6166-6167h                   |
| 13      | 6168-6169h             | 616A-616Bh              | 616C-616Dh                   | 616E-616Fh                   |
| 14      | 6170-6171h             | 6172-6173h              | 6174-6175h                   | 6176-6177h                   |
| 15      | 6178-6179h             | 617A-617Bh              | 617C-617Dh                   | 617E-617Fh                   |
| 16      | 6180-6181h             | 6182-6183h              | 6184-6185h                   | 6186-6187h                   |
| 17      | 6188-6189h             | 618A-618Bh              | 618C-618Dh                   | 618E-618Fh                   |
| 18      | 6190-6191h             | 6192-6193h              | 6194-6195h                   | 6196-6197h                   |
| 19      | 6198-6199h             | 619A-619Bh              | 619C-619Dh                   | 619E-619Fh                   |
| 20      | 61A0-61A1h             | 61A2-61A3h              | 61A4-61A5h                   | 61A6-61A7h                   |
| 21      | 61A8-61A9h             | 61AA-61ABh              | 61AC-61ADh                   | 61AE-61AFh                   |
| 22      | 61B0-61B1h             | 61B2-61B3h              | 61B4-61B5h                   | 61B6-61B7h                   |
| 23      | 61B8-61B9h             | 61BA-61BBh              | 61BC-61BDh                   | 61BE-61BFh                   |
| 24      | 61C0-61C1h             | 61C2-61C3h              | 61C4-61C5h                   | 61C6-61C7h                   |
| 25      | 61C8-61C9h             | 61CA-61CBh              | 61CC-61CDh                   | 61CE-61CFh                   |
| 26      | 61D0-61D1h             | 61D2-61D3h              | 61D4-61D5h                   | 61D6-61D7h                   |
| 27      | 61D8-61D9h             | 61DA-61DBh              | 61DC-61DDh                   | 61DE-61DFh                   |
| 28      | 61E0-61E1h             | 61E2-61E3h              | 61E4-61E5h                   | 61E6-61E7h                   |
| 29      | 61E8-61E9h             | 61EA-61EBh              | 61EC-61EDh                   | 61EE-61EFh                   |
| 30      | 61F0-61F1h             | 61F2-61F3h              | 61F4-61F5h                   | 61F6-61F7h                   |
| 31      | 61F8-61F9h             | 61FA-61FBh              | 61FC-61FDh                   | 61FE-61FFh                   |

| www.ti.com |
|------------|
|------------|

Message Mailbox

| Mailbox        | LAM         | MOTS        | MOT0        |  |
|----------------|-------------|-------------|-------------|--|
| 0              | 6040h-6041h | 6080h-6081h | 60C0h-60C1h |  |
| 1              | 6042h-6043h | 6082h-6083h | 60C2h-60C3h |  |
| 2              | 6044h-6045h | 6084h-6085h | 60C4h-60C5h |  |
| 3              | 6046h-6047h | 6086h-6087h | 60C6h-60C7h |  |
| 4              | 6048h-6049h | 6088h-6089h | 60C8h-60C9h |  |
| 5              | 604Ah-604Bh | 608Ah-608Bh | 60CAh-60CBh |  |
| 6              | 604Ch-604Dh | 608Ch-608Dh | 60CCh-60CDh |  |
| 7              | 604Eh-604Fh | 608Eh-608Fh | 60CEh-60CFh |  |
| 8              | 6050h-6051h | 6090h-6091h | 60D0h-60D1h |  |
| 9              | 6052h-6053h | 6092h-6093h | 60D2h-60D3h |  |
| 10             | 6054h-6055h | 6094h-6095h | 60D4h-60D5h |  |
| 11             | 6056h-6057h | 6096h-6097h | 60D6h-60D7h |  |
| 12             | 6058h-6059h | 6098h-6099h | 60D8h-60D9h |  |
| 13 605Ah-605Bh |             | 609Ah-609Bh | 60DAh-60DBh |  |
| 14 605Ch-605Dh |             | 609Ch-609Dh | 60DCh-60DDh |  |
| 15             | 605Eh-605Fh | 609Eh-609Fh | 60DEh-60DFh |  |
| 16             | 6060h-6061h | 60A0h-60A1h | 60E0h-60E1h |  |
| 17             | 6062h-6063h | 60A2h-60A3h | 60E2h-60E3h |  |
| 18             | 6064h-6065h | 60A4h-60A5h | 60E4h-60E5h |  |
| 19             | 6066h-6067h | 60A6h-60A7h | 60E6h-60E7h |  |
| 20             | 6068h-6069h | 60A8h-60A9h | 60E8h-60E9h |  |
| 21             | 606Ah-606Bh | 60AAh-60ABh | 60EAh-60EBh |  |
| 22             | 606Ch-606Dh | 60ACh-60ADh | 60ECh-60EDh |  |
| 23             | 606Eh-606Fh | 60AEh-60AFh | 60EEh-60EFh |  |
| 24             | 6070h-6071h | 60B0h-60B1h | 60F0h-60F1h |  |
| 25             | 6072h-6073h | 60B2h-60B3h | 60F2h-60F3h |  |
| 26             | 6074h-6075h | 60B4h-60B5h | 60F4h-60F5h |  |
| 27             | 6076h-6077h | 60B6h-60B7h | 60F6h-60F7h |  |
| 28             | 6078h-6079h | 60B8h-60B9h | 60F8h-60F9h |  |
| 29             | 607Ah-607Bh | 60BAh-60BBh | 60FAh-60FBh |  |
| 30             | 607Ch-607Dh | 60BCh-60BDh | 60FCh-60FDh |  |
| 31             | 607Eh-607Fh | 60BEh-60BFh | 60FEh-60FFh |  |

### Table 12-4. Message Object Behavior Configuration

| Message Object Behavior | Mailbox Direction Register<br>(CANMD) | Auto-Answer Mode Bit<br>(AAM) | Remote Transmission<br>Request Bit (RTR) |
|-------------------------|---------------------------------------|-------------------------------|------------------------------------------|
| Transmit message object | 0                                     | 0                             | 0                                        |
| Receive message object  | 1                                     | 0                             | 0                                        |
| Request message object  | 1                                     | 0                             | 1                                        |
| Reply message object    | 0                                     | 1                             | 0                                        |

### 12.5.1 Transmit Mailbox

The CPU stores the data to be transmitted in a mailbox configured as transmit mailbox. After writing the data and the identifier into the RAM, the message is sent if the corresponding TRS[n] bit has been set, provided the mailbox is enabled by setting the corresponding the CANME.n bit.



eCAN Registers

If more than one mailbox is configured as transmit mailbox and more than one corresponding TRS[n] is set, the messages are sent one after another in falling order beginning with the mailbox with the highest priority.

In the SCC-compatibility mode, the priority of the mailbox transmission depends on the mailbox number. The highest mailbox number (=15) comprises the highest transmit priority.

In the eCAN mode, the priority of the mailbox transmission depends on the setting of the TPL field in the message control field (MSGCTRL) register. The mailbox with the highest value in the TPL is transmitted first. Only when two mailboxes have the same value in the TPL is the higher numbered mailbox transmitted first.

If a transmission fails due to a loss of arbitration or an error, the message transmission will be reattempted. Before reattempting the transmission, the CAN module checks if other transmissions are requested and then transmits the mailbox with the highest priority.

### 12.5.2 Receive Mailbox

The identifier of each incoming message is compared to the identifiers held in the receive mailboxes using the appropriate mask. When equality is detected, the received identifier, the control bits, and the data bytes are written into the matching RAM location. At the same time, the corresponding receive-message-pending bit, RMP[n] (RMP.31-0), is set and a receive interrupt is generated if enabled. If no match is detected, the message is not stored.

When a message is received, the message controller starts looking for a matching identifier at the mailbox with the highest mailbox number. Mailbox 15 of the eCAN in SCC compatible mode has the highest receive priority; mailbox 31 has the highest receive priority of the eCAN in eCAN mode.

RMP[n] (RMP.31-0) has to be reset by the CPU after reading the data. If a second message has been received for this mailbox and the receive-message-pending bit is already set, the corresponding message-lost bit (RML[n] (RML.31-0)) is set. In this case, the stored message is overwritten with the new data if the overwrite-protection bit OPC[n] (OPC.31-0) is cleared; otherwise, the next mailboxes are checked.

If a mailbox is configured as a receive mailbox and the RTR bit is set for it, the mailbox can send a remote frame. Once the remote frame is sent, the TRS bit of the mailbox is cleared by the CAN module.

### 12.5.3 CAN Module Operation in Normal Configuration

If the CAN module is being used in normal configuration (i.e., not in self-test mode), there should be at least one more CAN module on the network, configured for the same bit rate. The other CAN module need NOT be configured to actually receive messages from the transmitting node. But, it should be configured for the same bit rate. This is because a transmitting CAN module expects at least one node in the CAN network to acknowledge the proper reception of a transmitted message. Per CAN protocol specification, any CAN node that received a message will acknowledge (unless the acknowledge mechanism has been explicitly turned off), irrespective of whether it has been configured to store the received message or not. It is not possible to turn off the acknowledge mechanism in these DSPs.

The requirement of another node does not exist for the self-test mode (STM). In this mode, a transmitting node generates its own acknowledge signal. The only requirement is that the node be configured for any valid bit-rate. That is, the bit timing registers should not contain a value that is not permitted by the CAN protocol.

It is not possible to achieve a direct digital loopback externally by connecting the CANTX and CANRX pins together (as is possible with SCI/SPI/McBSP modules). An internal loopback is possible in the self-test mode (STM).

### 12.6 eCAN Registers

### 12.6.1 Mailbox Enable Register (CANME)

This register is used to enable/disable individual mailboxes.



31

0

## Figure 12-5. Mailbox-Enable Register (CANME)

CANME[31:0]

R/W-0

LEGEND: R/W = Read/Write; -*n* = value after reset

# Table 12-5. Mailbox-Enable Register (CANME) Field Descriptions

| Bit  | Field       | Value | Description                                                                                                                                                                                                                                        |
|------|-------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | CANME[31:0] |       | Mailbox enable bits. After power-up, all bits in CANME are cleared. Disabled mailboxes can be used as additional memory for the CPU.                                                                                                               |
|      |             | 1     | The corresponding mailbox is enabled for the CAN module. The mailbox must be disabled before writing to the contents of any identifier field. If the corresponding bit in CANME is set, the write access to the identifier of a mailbox is denied. |
|      |             | 0     | The corresponding mailbox RAM area is disabled for the eCAN; however, it is accessible to the CPU as normal RAM.                                                                                                                                   |

~

~4

# 12.6.2 Mailbox-Direction Register (CANMD)

This register is used to configure a mailbox for transmit or receive operation.

### Figure 12-6. Mailbox-Direction Register (CANMD)

| 31          | 0 |
|-------------|---|
| CANMD[31:0] |   |
| R/W-0       |   |

LEGEND: R/W = Read/Write; -n = value after reset

### Table 12-6. Mailbox-Direction Register (CANMD) Field Descriptions

| Bit  | Field       | Value | Description                                                    |
|------|-------------|-------|----------------------------------------------------------------|
| 31:0 | CANMD[31:0] |       | Mailbox direction bits. After power-up, all bits are cleared.  |
|      |             | 1     | The corresponding mailbox is configured as a receive mailbox.  |
|      |             | 0     | The corresponding mailbox is configured as a transmit mailbox. |



### 12.6.3 Transmission-Request Set Register (CANTRS)

When mailbox n is ready to be transmitted, the CPU should set the TRS[n] bit to 1 to start the transmission.

These bits are normally set by the CPU and cleared by the CAN module logic. The CAN module can set these bits for a remote frame request. These bits are reset when a transmission is successful or aborted. If a mailbox is configured as a receive mailbox, the corresponding bit in CANTRS is ignored unless the receive mailbox is configured to handle remote frames. The TRS[n] bit of a receive mailbox is not ignored if the RTR bit is set. Therefore, a receive mailbox (whose RTR is set) can send a remote frame if its TRS bit is set. Once the remote frame is sent, the TRS[n] bit is cleared by the CAN module. Therefore, the same mailbox can be used to request a data frame from another mode. If the CPU tries to set a bit while the eCAN module tries to clear it, the bit is set.

Setting CANTRS[n] causes the particular message n to be transmitted. Several bits can be set simultaneously. Therefore, all messages with the TRS bit set are transmitted in turn, starting with the mailbox having the highest mailbox number (= highest priority), unless TPL bits dictate otherwise.

The bits in CANTRS are set by writing a 1 from the CPU. Writing a 0 has no effect. After power up, all bits are cleared.

### Figure 12-7. Transmission-Request Set Register (CANTRS)

| 31        | 0 |
|-----------|---|
| TRS[31:0] |   |
| RS-0      |   |

LEGEND: RS = Read/Set; -n = value after reset

### Table 12-7. Transmission-Request Set Register (CANTRS) Field Descriptions

| Bit  | Field     | Value | Description                                                                                                                               |
|------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TRS[31:0] |       | Transmit-request-set bits                                                                                                                 |
|      |           | 1     | Setting TRS <i>n</i> transmits the message in that mailbox. Several bits can be set simultaneously with all messages transmitted in turn. |
|      |           | 0     | No operation                                                                                                                              |



eCAN Registers

### 12.6.4 Transmission-Request-Reset Register (CANTRR)

These bits can only be set by the CPU and reset by the internal logic. These bits are reset when a transmission is successful or is aborted. If the CPU tries to set a bit while the CAN tries to clear it, the bit is set.

Setting the TRR[n] bit of the message object *n* cancels a transmission request if it was initiated by the corresponding bit (TRS[n]) and is not currently being processed. If the corresponding message is currently being processed, the bit is reset when a transmission is successful (normal operation) or when an aborted transmission due to a lost arbitration or an error condition is detected on the CAN bus line. When a transmission is aborted, the corresponding status bit (AA.31-0) is set. When a transmission is successful, the status bit (TA.31-0) is set. The status of the transmission request reset can be read from the TRS.31-0 bit.

The bits in CANTRR are set by writing a 1 from the CPU.

### Figure 12-8. Transmission-Request-Reset Register (CANTRR)

| 31 |           | 0 |
|----|-----------|---|
|    | TRR[31:0] |   |
|    | RS-0      |   |

LEGEND: RS = Read/Set; -*n* = value after reset

### Table 12-8. Transmission-Request-Reset Register (CANTRR) Field Descriptions

| Bit  | Field     | Value | Description                                         |
|------|-----------|-------|-----------------------------------------------------|
| 31:0 | TRR[31:0] |       | Transmit-request-reset bits                         |
|      |           | 1     | Setting TRR <i>n</i> cancels a transmission request |
|      |           | 0     | No operation                                        |

### 12.6.5 Transmission-Acknowledge Register (CANTA)

If the message of mailbox *n* was sent successfully, the bit TA[*n*] is set. This also sets the GMIF0/GMIF1 (GIF0.15/GIF1.15) bit if the corresponding interrupt mask bit in the CANMIM register is set. The GMIF0/GMIF1 bit initiates an interrupt.

The CPU resets the bits in CANTA by writing a 1. This also clears the interrupt if an interrupt has been generated. Writing a 0 has no effect. If the CPU tries to reset the bit while the CAN tries to set it, the bit is set. After power-up, all bits are cleared.

### Figure 12-9. Transmission-Acknowledge Register (CANTA)

| 31 |          | 0 |
|----|----------|---|
|    | TA[31:0] |   |
|    | RC-0     |   |

LEGEND: RC = Read/Clear; -*n* = value after reset

### Table 12-9. Transmission-Acknowledge Register (CANTA) Field Descriptions

| Bit  | Field    | Value | Description                                                                              |
|------|----------|-------|------------------------------------------------------------------------------------------|
| 31:0 | TA[31:0] |       | Transmit-acknowledge bits                                                                |
|      |          | 1     | If the message of mailbox $n$ is sent successfully, the bit $n$ of this register is set. |
|      |          | 0     | The message is not sent.                                                                 |



### 12.6.6 Abort-Acknowledge Register (CANAA)

If the transmission of the message in mailbox *n* was aborted, the bit AA[*n*] is set and the AAIF (GIF.14) bit is set, which may generate an interrupt if enabled.

The bits in CANAA are reset by writing a 1 from the CPU. Writing a 0 has no effect. If the CPU tries to reset a bit and the CAN tries to set the bit at the same time, the bit is set. After power-up all bits are cleared.

### Figure 12-10. Abort-Acknowledge Register (CANAA)

| 31 | 0        |   |
|----|----------|---|
|    | AA[31:0] | ] |
|    | RC-0     |   |

LEGEND: RC = Read/Clear; -*n* = value after reset

### Table 12-10. Abort-Acknowledge Register (CANAA) Field Descriptions

| Bit  | Field    | Value | Description                                                                                        |  |
|------|----------|-------|----------------------------------------------------------------------------------------------------|--|
| 31:0 | AA[31:0] |       | Abort-acknowledge bits                                                                             |  |
|      |          | 1     | If the transmission of the message in mailbox $n$ is aborted, the bit $n$ of this register is set. |  |
|      |          | 0     | The transmission is not aborted.                                                                   |  |

www.ti.com

## 12.6.7 Received-Message-Pending Register (CANRMP)

If mailbox *n* contains a received message, the bit RMP[n] of this register is set. These bits can be reset only by the CPU and set by the internal logic. A new incoming message overwrites the stored one if the OPC[n](OPC.31-0) bit is cleared, otherwise the next mailboxes are checked for a matching ID. If a mailbox is overwritten, the corresponding status bit RML[n] is set. The bits in the CANRMP and the CANRML registers are cleared by a write to register CANRMP, with a 1 at the corresponding bit location. If the CPU tries to reset a bit and the CAN tries to set the bit at the same time, the bit is set.

The bits in the CANRMP register can set GMIF0/GMIF1 (GIF0.15/GIF1.15) if the corresponding interrupt mask bit in the CANMIM register is set. The GMIF0/GMIF1 bit initiates an interrupt.

### Figure 12-11. Received-Message-Pending Register (CANRMP)

| 31 |           | 0 |
|----|-----------|---|
|    | RMP[31:0] |   |
|    | RC-0      |   |

LEGEND: RC = Read/Clear; -*n* = value after reset

### Table 12-11. Received-Message-Pending Register (CANRMP) Field Descriptions

| Bit  | Field     | Value | Description                                                                                   |
|------|-----------|-------|-----------------------------------------------------------------------------------------------|
| 31:0 | RMP[31:0] |       | Received-message-pending bits                                                                 |
|      |           | 1     | If mailbox <i>n</i> contains a received message, bit RMP[ <i>n</i> ] of this register is set. |
|      |           | 0     | The mailbox does not contain a message.                                                       |



### 12.6.8 Received-Message-Lost Register (CANRML)

An RML[n] bit is set if an old message has been overwritten by a new one in mailbox n. These bits can only be reset by the CPU, and set by the internal logic. The bits can be cleared by a write access to the CANRMP register with a 1 at the corresponding bit location. If the CPU tries to reset a bit and the CAN tries to set the bit at the same time, the bit is set. The CANRML register is not changed if the OPC[n] (OPC.31-0) bit is set.

If one or more of the bits in the CANRML register are set, the RMLIF (GIF0.11/ GIF1.11) bit is also set. This can initiate an interrupt if the RMLIM (GIM.11) bit is set.

### Figure 12-12. Received-Message-Lost Register (CANRML)

| 31 |           | 0 |
|----|-----------|---|
|    | RML[31:0] |   |
|    | R-0       |   |

LEGEND: R = Read; -n = value after reset

### Table 12-12. Received-Message-Lost Register (CANRML) Field Descriptions

| Bit  | Field     | Value | Description                                                                 |
|------|-----------|-------|-----------------------------------------------------------------------------|
| 31:0 | RML[31:0] |       | Received-message-lost bits                                                  |
|      |           | 1     | An old unread message has been overwritten by a new one in that mailbox.    |
|      |           | 0     | No message was lost.                                                        |
|      |           |       | Note: The RML <i>n</i> bit is cleared by clearing the set RMP <i>n</i> bit. |

21

Λ

### 12.6.9 Remote-Frame-Pending Register (CANRFP)

Whenever a remote frame request is received by the CAN module, the corresponding bit RFP[*n*] in the remote frame pending register is set. If a remote frame is stored in a receive mailbox (AAM=0, CANMD=1), the RFP*n* bit will not be set.

To prevent an auto-answer mailbox from replying to a remote frame request, the CPU has to clear the RFP[n] flag and the TRS[n] bit by setting the corresponding transmission request reset bit TRR[n]. The AAM bit can also be cleared by the CPU to stop the module from sending the message.

If the CPU tries to reset a bit and the CAN module tries to set the bit at the same time, the bit is not set. The CPU cannot interrupt an ongoing transfer.

### Figure 12-13. Remote-Frame-Pending Register (CANRFP)

| 51 | 0        |
|----|----------|
|    | RFP.31:0 |
|    | RC-0     |

LEGEND: RC = Read/Clear; -*n* = value after reset

### Table 12-13. Remote-Frame-Pending Register (CANRFP) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                         |  |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:0 | RFP.31:0 |       | Remote-frame-pending register.                                                                                                                                                      |  |
|      |          |       | For a receive mailbox, RFP <i>n</i> is set if a remote frame is received and TRS <i>n</i> is not affected.                                                                          |  |
|      |          |       | For a transmit mailbox, RFP <i>n</i> is set if a remote frame is received and TRS <i>n</i> is set if AAM of the mailbox is 1. The ID of the mailbox must match the remote frame ID. |  |
|      |          | 1     | A remote-frame request was received by the module.                                                                                                                                  |  |
|      |          | 0     | No remote-frame request was received. The register is cleared by the CPU.                                                                                                           |  |

### 12.6.9.1 Handling of Remote Frames

If a remote frame is received (the incoming message has RTR (MSGCTRL.4) = 1), the CAN module compares the identifier to all identifiers of the mailboxes using the appropriate masks starting at the highest mailbox number in descending order.

In the case of a matching identifier (with the message object configured as send mailbox and AAM (MSGID.29) in this message object set) this message object is marked as to be sent (TRS[*n*] is set).

In case of a matching identifier with the mailbox configured as a send mailbox and bit AAM in this mailbox is not set, this message is not received in that mailbox.

After finding a matching identifier in a send mailbox no further compare is done.

With a matching identifier and the message object configured as receive mailbox, this message is handled like a data frame and the corresponding bit in the receive message pending (CANRMP) register is set. The CPU then has to decide how to handle this situation. For information about the CANRMP register, see Section 12.6.7.

For the CPU to change the data in a mailbox that is configured as a remote frame mailbox (AAM set) it has to set the mailbox number and the change data request bit (CDR [MC.8]) in the MCR first. The CPU can then do the access and clear the CDR bit to tell the eCAN that the access is finished. Until the CDR bit is cleared, the transmission of this mailbox is not permitted. Therefore, the newest data is sent.

To change the identifier in that mailbox, the mailbox must be disabled first (CANMEn = 0).

For the CPU to request data from another node it configures the mailbox as a receive mailbox and sets the TRS bit. In this case the module sends a remote frame request and receives the data frame in the same mailbox that sent the request. Therefore, only one mailbox is necessary to do a remote request. Note that the CPU must set RTR (MSGCTRL.4) to enable a remote frame transmission. Once the remote frame is sent, the TRS bit of the mailbox is cleared by CAN. In this case, bit TA*n* will not be set for that mailbox.



The behavior of the message object *n* is configured with CANMD[*n*] (CANMD.31-0), the AAM (MSGID.29), and RTR (MSGCTRL.4). It shows how to configure a message object according to the desired behavior.

To summarize, a message object can be configured with four different behaviors:

- 1. A transmit message object is only able to transmit messages.
- 2. A receive message object is only able to receive messages.
- 3. A request message object is able to transmit a remote request frame and to wait for the corresponding data frame.
- 4. A reply message object is able to transmit a data frame whenever a remote request frame is received for the corresponding identifier.
  - **NOTE:** When a remote transmission request is successfully transmitted with a message object configured in request mode, the CANTA register is not set and no interrupt is generated. When the remote reply message is received, the behavior of the message object is the same as a message object configured in receive mode.



### 12.6.10 Global Acceptance Mask Register (CANGAM)

The global-acceptance mask is used by the eCAN in SCC mode. The global-acceptance mask is used for the mailboxes 6 to 15 if the AME bit (MSGID.30) of the corresponding mailbox is set. A received message is only stored in the first mailbox with a matching identifier.

The global-acceptance mask is used for the mailboxes 6 to 15 of the SCC.

### Figure 12-14. Global Acceptance Mask Register (CANGAM)

| 31    | 30   | 29   | 28 |            | 16 |
|-------|------|------|----|------------|----|
| AMI   | Rese | rved |    | GAM[28:16] |    |
| RWI-0 | R-   | 0    |    | RWI-0      |    |
| 15    |      |      |    |            | 0  |
|       |      |      |    | GAM[28:16] |    |
|       |      |      |    |            |    |

RWI-0

LEGEND: RWI = Read at any time, write during initialization mode only; -n = value after reset

### Table 12-14. Global Acceptance Mask Register (CANGAM) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                       |
|-------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | AMI      |       | Acceptance-mask-identifier extension bit                                                                                                                                                                                                                                                                                                          |
|       |          | 1     | Standard and extended frames can be received. In case of an extended frame, all 29 bits of the identifier are stored in the mailbox and all 29 bits of global acceptance mask register are used for the filter. In case of a standard frame, only the first eleven bits (bit 28 to 18) of the identifier and the global acceptance mask are used. |
|       |          |       | The IDE bit of the receive mailbox is a "don't care" and is overwritten by the IDE bit of the transmitted message. The filtering criterion must be satisfied in order to receive a message. The number of bits to be compared is a function of the value of the IDE bit of the transmitted message.                                               |
|       |          | 0     | The identifier extension bit stored in the mailbox determines which messages shall be received.<br>The IDE bit of the receive mailbox determines the number of bits to be compared. Filtering is not<br>applicable. The MSGIDs must match bit-for-bit in order to receive a message.                                                              |
| 30:29 | Reserved |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                    |
| 28:0  | GAM 28:0 |       | Global-acceptance mask. These bits allow any identifier bits of an incoming message to be masked. Accept a 0 or a 1 (don't care) for the corresponding bit of the received identifier. Received identifier bit value must match the corresponding identifier bit of the MSGID register.                                                           |

## 12.6.11 Master Control Register (CANMC)

This register is used to control the settings of the CAN module. Some bits of the CANMC register are EALLOW protected. For read/write operations, only 32-bit access is supported.

|        |        |        |         |        | •      | ,      |     |       |
|--------|--------|--------|---------|--------|--------|--------|-----|-------|
| 31     |        |        |         |        |        |        | 17  | 16    |
|        |        |        | Reserve | d      |        |        |     | SUSP  |
|        |        |        | R-0     |        |        |        |     | R/W-0 |
| 15     | 14     | 13     | 12      | 11     | 10     | 9      |     | 8     |
| MBCC   | TCC    | SCB    | CCR     | PDR    | DBO    | WUBA   | С   | DR    |
| R/WP-0 | SP-x   | R/WP-0 | R/WP-1  | R/WP-0 | R/WP-0 | R/WP-0 | R/V | VP-0  |
| 7      | 6      | 5      | 4       |        |        |        |     | 0     |
| ABO    | STM    | SRES   |         |        | MBNR   |        |     |       |
| R/WP-0 | R/WP-0 | R/S-0  |         |        | R/W-0  |        |     |       |

### Figure 12-15. Master Control Register (CANMC)

LEGEND: R = Read, WP = Write in EALLOW mode only, S = Set in EALLOW mode only; -n = value after reset; x = Indeterminate Note: eCAN only, reserved in the SCC

### Table 12-15. Master Control Register (CANMC) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 16    | SUSP     |       | SUSPEND. This bit determines the action of the CAN module in SUSPEND (emulation stop such as breakpoint or single stepping).                                                                                                                                                                                                                                                                                                                                                                                |
|       |          | 1     | FREE mode. The peripheral continues to run in SUSPEND. The node would participate in CAN communication normally (sending acknowledge, generating error frames, transmitting/receiving data) while in SUSPEND.                                                                                                                                                                                                                                                                                               |
|       |          | 0     | SOFT mode. The peripheral shuts down during SUSPEND after the current transmission is complete.                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15    | MBCC     |       | Mailbox timestamp counter clear bit. This bit is reserved in SCC mode and it is EALLOW protected.                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | 1     | The time stamp counter is reset to 0 after a successful transmission or reception of mailbox 16.                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |          | 0     | The time stamp counter is not reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 14    | TCC      |       | Time stamp counter MSB clear bit. This bit is reserved in SCC mode and it is EALLOW protected.                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |          | 1     | The MSB of the time stamp counter is reset to 0. The TCC bit is reset after one clock cycle by the internal logic.                                                                                                                                                                                                                                                                                                                                                                                          |
|       |          | 0     | The time stamp counter is not changed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 13    | SCB      |       | SCC compatibility bit. This bit is reserved in SCC mode and it is EALLOW protected.                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |          | 1     | Select eCAN mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | 0     | The eCAN is in SCC mode. Only mailboxes 15 to 0 can be used.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 12    | CCR      |       | Change-configuration request. This bit is EALLOW protected.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |          | 1     | The CPU requests write access to the configuration register CANBTC and the acceptance mask registers (CANGAM, LAM[0], and LAM[3]) of the SCC. After setting this bit, the CPU must wait until the CCE flag of CANES register is at 1 before proceeding to the CANBTC register.                                                                                                                                                                                                                              |
|       |          |       | The CCR bit will also be set upon a bus-off condition, if the ABO bit is not set. The BO condition can be exited by clearing this bit (after 128 * 11 consecutive recessive bits on the bus).                                                                                                                                                                                                                                                                                                               |
|       |          | 0     | The CPU requests normal operation. This can be done only after the configuration register CANBTC was set to the allowed values. It also exits the bus-off state after the obligatory bus-off recovery sequence.                                                                                                                                                                                                                                                                                             |
| 11    | PDR      |       | Power down mode request. This bit is automatically cleared by the eCAN module upon wakeup from low-power mode. This bit is EALLOW protected.                                                                                                                                                                                                                                                                                                                                                                |
|       |          | 1     | The local power-down mode is requested.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |          | 0     | The local power-down mode is not requested (normal operation).                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |          |       | <b>Note:</b> If an application sets the TRS <i>n</i> bit for a mailbox and then immediately sets the PDR bit, the CAN module goes into LPM without transmitting the data frame. This is because it takes about 80 CPU cycles for the data to be transferred from the mailbox RAM to the transmit buffer. Therefore, the application has to ensure that any pending transmission has been completed before writing to the PDR bit. The TA <i>n</i> bit could be polled to ensure completion of transmission. |



| D:4 |          |       |                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                      |
| 10  | DBO      |       | Data byte order. This bit selects the byte order of the message data field. This bit is EALLOW protected.                                                                                                                                                                                                                                                                                        |
|     |          | 1     | The data is received or transmitted least significant byte first.                                                                                                                                                                                                                                                                                                                                |
|     |          | 0     | The data is received or transmitted most significant byte first.                                                                                                                                                                                                                                                                                                                                 |
| 9   | WUBA     |       | Wake up on bus activity. This bit is EALLOW protected.                                                                                                                                                                                                                                                                                                                                           |
|     |          | 1     | The module leaves the power-down mode after detecting any bus activity.                                                                                                                                                                                                                                                                                                                          |
|     |          | 0     | The module leaves the power-down mode only after writing a 0 to the PDR bit.                                                                                                                                                                                                                                                                                                                     |
| 8   | CDR      |       | Change data field request. This bit allows fast data message update.                                                                                                                                                                                                                                                                                                                             |
|     |          | 1     | The CPU requests write access to the data field of the mailbox specified by the MBNR.4:0 field (MC.4-0). The CPU must clear the CDR bit after accessing the mailbox. The module does not transmit that mailbox content while the CDR is set. This is checked by the state machine before and after it reads the data from the mailbox to store it in the transmit buffer.                        |
|     |          |       | <b>Note:</b> Once the TRS bit is set for a mailbox and then data is changed in the mailbox using the CDR bit, the CAN module fails to transmit the new data and transmits the old data instead. To avoid this, reset transmission in that mailbox using the TRR <i>n</i> bit and set the TRS <i>n</i> bit again. The new data is then transmitted.                                               |
|     |          | 0     | The CPU requests normal operation.                                                                                                                                                                                                                                                                                                                                                               |
| 7   | ABO      |       | Auto bus on. This bit is EALLOW protected.                                                                                                                                                                                                                                                                                                                                                       |
|     |          | 1     | After the bus-off state, the module goes back automatically into bus-on state after 128 * 11 recessive bits have been monitored.                                                                                                                                                                                                                                                                 |
|     |          | 0     | The bus-off state may only be exited after 128 * 11 consecutive recessive bits on the bus and after having cleared the CCR bit.                                                                                                                                                                                                                                                                  |
| 6   | STM      |       | Self test mode. This bit is EALLOW protected.                                                                                                                                                                                                                                                                                                                                                    |
|     |          | 1     | The module is in self-test mode. In this mode, the CAN module generates its own acknowledge (ACK) signal, thus enabling operation without a bus connected to the module. The message is not sent, but read back and stored in the appropriate mailbox. The MSGID of the received frame is not stored in the MBR in STM.                                                                          |
|     |          |       | <b>Note:</b> In STM, if no MBX has been configured to receive a transmitted frame, then that frame will be stored in MBX0, even if MBX0 has not been configured for receive operations. If LAMs are configured such that some mailboxes can receive and store data frames, then a data frame that does not satisfy the acceptance mask filtering criterion for any receive mailbox will be lost. |
|     |          | 0     | The module is in normal mode.                                                                                                                                                                                                                                                                                                                                                                    |
| 5   | SRES     |       | This bit can only be written and is always read as zero.                                                                                                                                                                                                                                                                                                                                         |
|     |          | 1     | A write access to this register causes a software reset of the module (all parameters, except the protected registers, are reset to their default values). The mailbox contents and the error counters are not modified. Pending and ongoing transmissions are canceled without perturbing the communication.                                                                                    |
|     |          | 0     | 0 No effect                                                                                                                                                                                                                                                                                                                                                                                      |
| 4:0 | MBNR 4:0 |       | Mailbox number                                                                                                                                                                                                                                                                                                                                                                                   |
|     |          | 1     | The bit MBNR.4 is for eCAN only, and is reserved in the SCC.                                                                                                                                                                                                                                                                                                                                     |
|     |          | 0     | Number of mailbox, for which the CPU requests a write access to the data field. This field is used in conjunction with the CDR bit.                                                                                                                                                                                                                                                              |

### Table 12-15. Master Control Register (CANMC) Field Descriptions (continued)

### 12.6.11.1 CAN Module Action in SUSPEND

- 1. If there is no traffic on the CAN bus and SUSPEND mode is requested, the node goes into SUSPEND mode.
- 2. If there is traffic on the CAN bus and SUSPEND mode is requested, the node goes into SUSPEND mode when the ongoing frame is over.
- 3. If the node was transmitting, when SUSPEND is requested, it goes to SUSPEND state after it gets the acknowledgment. If it does not get an acknowledgment or if there are some other errors, it transmits an error frame and then goes to SUSPEND state. The TEC is modified accordingly. In the second case, i.e., it is suspended after transmitting an error frame, the node re-transmits the original frame after coming out of suspended state. The TEC is modified after transmission of the frame accordingly.
- 4. If the node was receiving, when SUSPEND is requested, it goes to SUSPEND state after transmitting



the acknowledgment bit. If there is any error, the node sends an error frame and go to SUSPEND state. The REC is modified accordingly before going to SUSPEND state.

- 5. If there is no traffic on the CAN bus and SUSPEND removal is requested, the node comes out of SUSPEND state.
- 6. If there is traffic on the CAN bus and SUSPEND removal is requested, the node comes out after the bus goes to idle. Therefore, a node does not receive any "partial" frame, which could lead to generation of error frames.
- 7. When the node is suspended, it does not participate in transmitting or receiving any data. Thus neither acknowledgment bit nor any error frame is sent. TEC and REC are not modified during SUSPEND state.

The CANBTC register is used to configure the CAN node with the appropriate network-timing parameters. This register must be programmed before using the CAN module.

Figure 12-16 Bit-Timing Configuration Register (CANBTC)

This register is write-protected in user mode and can only be written in initialization mode (see Section 3.6.1).

**NOTE:** To avoid unpredictable behavior of the CAN module, the CANBTC register should never be programmed with values not allowed by the CAN protocol specification and by the bit timing rules listed in Section 3.1.1.

|    | i igui   | C 12-10. |     | ining '          | connigui   | ation | vegisiei (CP         |                   |   |                      |
|----|----------|----------|-----|------------------|------------|-------|----------------------|-------------------|---|----------------------|
| 31 |          |          |     | 24               | 23         |       |                      |                   |   | 16                   |
|    | Reserved |          |     |                  |            |       | В                    | RP <sub>reg</sub> |   |                      |
|    | R-x      |          |     |                  |            |       | RV                   | NPI-0             |   |                      |
| 15 |          | 10       | 9   | 8                | 7          | 6     |                      | 3                 | 2 | 0                    |
|    | Reserved |          | SJ/ | N <sub>reg</sub> | SAM        |       | TSEG1 <sub>reg</sub> |                   |   | TSEG2 <sub>reg</sub> |
|    | R-0      |          | RW  | PI-0             | RWPI-<br>0 |       | RWPI-0               |                   |   | RWPI-0               |

LEGEND: RWPI = Read in all modes, write in EALLOW mode during initialization mode only; -n = value after reset

| Bit   | Field                   | Value | Description                                                                                                                                                                                                                                                                                                                                                |
|-------|-------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved                |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                             |
| 23:16 | BRP <sub>reg</sub> .7:0 |       | Baud rate prescaler. This register sets the prescaler for the baud rate settings. The length of one TQ is defined by:                                                                                                                                                                                                                                      |
|       |                         |       | $TQ = \frac{1}{SYSCLKOUT/2} \times \left(BRP_{reg} + 1\right)$                                                                                                                                                                                                                                                                                             |
|       |                         |       | where SYSCLKOUT/2 is the frequency of the CAN module clock.                                                                                                                                                                                                                                                                                                |
|       |                         |       | BRP <sub>reg</sub> denotes the "register value" of the prescaler; i.e., value written into bits 23:16 of the CANBTC register. This value is automatically enhanced by 1 when the CAN module accesses it. The enhanced value is denoted by the symbol BRP (BRP = $BRP_{reg} + 1$ ). BRP is programmable from 1 to 256.                                      |
|       |                         |       | <b>Note:</b> For the special case of BRP = 1, the Information Processing Time (IPT) is equal to 3 time quanta (TQ). This is not compliant to the ISO 11898 Standard, where the IPT is defined to be less than or equal to 2 TQ. Thus the usage of this mode (BRP <sub>reg</sub> = 0) is not allowed.                                                       |
| 15    | Reserved                |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                             |
| 9:8   | SJW <sub>reg</sub> 1:0  |       | Synchronization jump width. The parameter SJW indicates, by how many units of TQ a bit is allowed to be lengthened or shortened when resynchronizing.                                                                                                                                                                                                      |
|       |                         |       | SJW <sub>reg</sub> denotes the "register value" of the "resynchronization jump width;" i.e., the value written into bits 9:8 of the CANBTC register. This value is automatically enhanced by 1 when the CAN module accesses it. This enhanced value is denoted by the symbol SJW.                                                                          |
|       |                         |       | $SJW = SJW_{reg} + 1$                                                                                                                                                                                                                                                                                                                                      |
|       |                         |       | SJW is programmable from 1 to 4 TQ. The maximum value of SJW is determined by the minimum value of TSEG2 and 4 TQ.                                                                                                                                                                                                                                         |
|       |                         |       | SJW <sub>(max)</sub> = min [4 TQ, TSEG2]                                                                                                                                                                                                                                                                                                                   |
| 7     | SAM                     |       | This parameter sets the number of samples used by the CAN module to determine the actual level of the CAN bus. When the SAM bit is set, the level determined by the CAN bus corresponds to the result from the majority decision of the last three values. The sample points are at the sample point and twice before with a distance of $\frac{1}{2}$ TQ. |
|       |                         |       | 1 The CAN module samples three times and make a majority decision. The triple sample mode shall be selected only for bit rate prescale values greater than 4 (BRP > 4).                                                                                                                                                                                    |
|       |                         |       | 0 The CAN module samples only once at the sampling point.                                                                                                                                                                                                                                                                                                  |

eCAN Registers



eCAN Registers

| www. | ti.com |
|------|--------|
|      |        |

| Bit | Field                | Value | Description                                                                                                                                                                                                                                                                                                   |
|-----|----------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:3 | TSEG1 3:0            |       | Time segment 1. The length of a bit on the CAN bus is determined by the parameters TSEG1, TSEG2, and BRP. All controllers on the CAN bus must have the same baud rate and bit length. For different clock frequencies of the individual controllers, the baud rate has to be adjusted by the said parameters. |
|     |                      |       | This parameter specifies the length of the TSEG1 segment in TQ units. TSEG1 combines PROP_SEG and PHASE_SEG1 segments:                                                                                                                                                                                        |
|     |                      |       | TSEG1 = PROP_SEG + PHASE_SEG1                                                                                                                                                                                                                                                                                 |
|     |                      |       | where PROP_SEG and PHASE_SEG1 are the length of these two segments in TQ units.                                                                                                                                                                                                                               |
|     |                      |       | TSEG1reg denotes the "register value" of "time segment 1;" i.e., the value written into bits 6:3 of the CANBTC register. This value is automatically enhanced by 1 when the CAN module accesses it. This enhanced value is denoted by the symbol TSEG1.                                                       |
|     |                      |       | TSEG1 = TSEG1 <sub>reg</sub> + 1                                                                                                                                                                                                                                                                              |
|     |                      |       | TSEG1 value should be chosen such that TSEG1 is greater than or equal to TSEG2 and IPT. For more information on IPT, see Section 3.1.1.                                                                                                                                                                       |
| 2:0 | TSEG2 <sub>reg</sub> |       | Time Segment 2. TSEG2 defines the length of PHASE_SEG2 segment in TQ units:                                                                                                                                                                                                                                   |
|     |                      |       | TSEG2 is programmable in the range of 1 TQ to 8 TQ and has to fulfill the following timing rule:                                                                                                                                                                                                              |
|     |                      |       | TSEG2 must be smaller than or equal to TSEG1 and must be greater than or equal to IPT.                                                                                                                                                                                                                        |
|     |                      |       | TSEG2reg denotes the "register value" of "time segment 2;" i.e., the value written into bits 2:0 of the CANBTC register. This value is automatically enhanced by 1 when the CAN module accesses it. This enhanced value is denoted by the symbol TSEG2.                                                       |
|     |                      |       | TSEG2 = TSEG2 <sub>reg</sub> + 1                                                                                                                                                                                                                                                                              |

# Table 12-16. Bit-Timing Configuration Register (CANBTC) Field Descriptions (continued)

# 12.6.13 Error and Status Register (CANES)

The status of the CAN module is shown by the Error and Status Register (CANES) and the error counter registers, which are described in this section.

The error and status register comprises information about the actual status of the CAN module and displays bus error flags as well as error status flags. If one of these error flags is set, then the current state of all other error flags is frozen. i.e. Only the first error is stored. In order to update the CANES register subsequently, the error flag which is set has to be acknowledged by writing a 1 to it. This action also clears the flag bit.

|    |          |    |      |      |     | •    |      |      |      |      |      |
|----|----------|----|------|------|-----|------|------|------|------|------|------|
| 31 |          | 25 | 24   | 23   | 22  | 21   | 20   | 19   | 18   | 17   | 16   |
|    | Reserved |    | FE   | BE   | SA1 | CRCE | SE   | ACKE | BO   | EP   | EW   |
|    | R-0      |    | RC-0 | RC-0 | R-1 | RC-0 | RC-0 | RC-0 | RC-0 | RC-0 | RC-0 |
| 15 |          |    |      |      | 6   | 5    | 4    | 3    | 2    | 1    | 0    |
|    | Reserved |    |      |      |     | SMA  | CCE  | PDA  | Rsvd | RM   | TM   |
|    | R-0      |    |      |      |     | R-0  | R-1  | R-0  | R-0  | R-0  | R-0  |

### Figure 12-17. Error and Status Register (CANES)

LEGEND: R = Read; C = Clear; -n = value after reset

### Table 12-17. Error and Status Register (CANES) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | Reserved |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 24    | FE       |       | Form error flag                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |          | 1     | A form error occurred on the bus. This means that one or more of the fixed-form bit fields had the wrong level on the bus.                                                                                                                                                                                                                                                                                                                      |
|       |          | 0     | No form error detected; the CAN module was able to send and receive correctly.                                                                                                                                                                                                                                                                                                                                                                  |
| 23    | BE       |       | Bit error flag                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |          | 1     | The received bit does not match the transmitted bit outside of the arbitration field or during transmission of the arbitration field, a dominant bit was sent but a recessive bit was received.                                                                                                                                                                                                                                                 |
|       |          | 0     | No bit error detected.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 22    | SA1      |       | Stuck at dominant error. The SA1 bit is always at 1 after a hardware reset, a software reset, or a Bus-Off condition. This bit is cleared when a recessive bit is detected on the bus.                                                                                                                                                                                                                                                          |
|       |          | 1     | The CAN module never detected a recessive bit.                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |          | 0     | The CAN module detected a recessive bit.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | CRCE     |       | CRC error.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |          | 1     | The CAN module received a wrong CRC.                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |          | 0     | The CAN module never received a wrong CRC.                                                                                                                                                                                                                                                                                                                                                                                                      |
| 20    | SE       |       | Stuff error.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       |          | 1     | A stuff bit error occurred.                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |          | 0     | No stuff bit error occurred.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 19    | ACKE     |       | Acknowledge error.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |          | 1     | The CAN module received no acknowledge.                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |          | 0     | All messages have been correctly acknowledged.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 18    | во       |       | Bus-off status. The CAN module is in bus-off state.                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 1     | There is an abnormal rate of errors on the CAN bus. This condition occurs when the transmit error counter (CANTEC) has reached the limit of 256. During Bus Off, no messages can be received or transmitted. The bus-off state can be exited by clearing the CCR bit in CANMC register or if the Auto Bus On (ABO) (CANMC.7) bit is set, after 128 * 11 receive bits have been received. After leaving Bus Off, the error counters are cleared. |
|       |          | 0     | Normal operation                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 17    | EP       |       | Error-passive state                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 1     | The CAN module is in error-passive mode. CANTEC has reached 128.                                                                                                                                                                                                                                                                                                                                                                                |
|       |          | 0     | The CAN module is in error-active mode.                                                                                                                                                                                                                                                                                                                                                                                                         |



| Bit  | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | EW       |       | Warning status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |          | 1     | One of the two error counters (CANREC or CANTEC) has reached the warning level of 96.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|      |          | 0     | Values of both error counters (CANREC and CANTEC) are less than 96.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15:6 | Reserved |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5    | SMA      |       | Suspend mode acknowledge. This bit is set after a latency of one clock cycle—up to the length of one frame—after the suspend mode was activated. The suspend mode is activated with the debugger tool when the circuit is not in run mode. During the suspend mode, the CAN module is frozen and cannot receive or transmit any frame. However, if the CAN module is transmitting or receiving a frame when the suspend mode is activated, the module enters suspend mode only at the end of the frame. Run mode is when SOFT mode is activated (CANMC.16 = 1). |
|      |          | 1     | The module has entered suspend mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |          | 0     | The module is not in suspend mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4    | CCE      |       | Change configuration enable. This bit displays the configuration access right. This bit is set after a latency of one clock cycle.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|      |          | 1     | The CPU has write access to the configuration registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      |          | 0     | The CPU is denied write access to the configuration registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      |          |       | <b>Note:</b> The reset state of the CCE bit is 1. That is, upon reset, you can write to the bit timing registers. However, once the CCE bit is cleared (as part of the module initialization), the CANRX pin must be sensed high before you can set the CCE bit to 1 again.                                                                                                                                                                                                                                                                                     |
| 3    | PDA      |       | Power-down mode acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      |          | 1     | The CAN module has entered the power-down mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|      |          | 0     | Normal operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2    | Reserved |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1    | RM       |       | Receive mode. The CAN module is in receive mode. This bit reflects what the CAN module is actually doing regardless of mailbox configuration.                                                                                                                                                                                                                                                                                                                                                                                                                   |
|      |          | 1     | The CAN module is receiving a message.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      |          | 0     | The CAN module is not receiving a message.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0    | ТМ       |       | Transmit mode. The CAN module is in transmit mode. This bit reflects what the CAN module is actually doing regardless of mailbox configuration.                                                                                                                                                                                                                                                                                                                                                                                                                 |

The CAN module is transmitting a message.

The CAN module is not transmitting a message.

# Table 12-17. Error and Status Register (CANES) Field Descriptions (continued)

1 0

## 12.6.14 CAN Error Counter Registers (CANTEC/CANREC)

The CAN module contains two error counters: the receive error counter (CANREC) and the transmit error counter (CANTEC). The values of both counters can be read via the CPU interface. These counters are incremented or decremented according to the CAN protocol specification version 2.0.

### Figure 12-18. Transmit-Error-Counter Register (CANTEC)

| 31 8     | 7 0 |
|----------|-----|
| Reserved | TEC |
| R-x      | R-0 |

LEGEND: R = Read only; -n = value after reset

### Figure 12-19. Receive-Error-Counter Register (CANREC)

| 31 8     | 7 0 |
|----------|-----|
| Reserved | REC |
| R-x      | R-0 |

LEGEND: R = Read only; -n = value after reset

After reaching or exceeding the error passive limit (128), the receive error counter will not be increased anymore. When a message was received correctly, the counter is set again to a value between 119 and 127 (compare with CAN specification).

After reaching the bus-off state, the transmit error counter is undefined while the receive error counter changes its function. After reaching the bus-off state, the receive error counter is cleared. It is then incremented after every 11 consecutive recessive bits on the bus. These 11 bits correspond to the gap between two frames on the bus. If the counter reaches 128, the module automatically changes back to the bus-on status if this feature is enabled (Auto Bus On bit (ABO) (MC.7) set). All internal flags are reset and the error counters are cleared. After leaving initialization mode, the error counters are cleared.



### 12.6.15 Interrupt Registers

Interrupts are controlled by the interrupt flag registers, interrupt mask registers and mailbox interrupt level registers. These registers are described in the following subsections.

### 12.6.15.1 Global Interrupt Flag Registers (CANGIF0/CANGIF1)

These registers allow the CPU to identify the interrupt source.

The interrupt flag bits are set if the corresponding interrupt condition did occur. The global interrupt flags are set depending on the setting of the GIL bit in the CANGIM register. If that bit is set, the global interrupts set the bits in the CANGIF1 register; otherwise, in the CANGIF0 register. This also applies to the Interrupt Flags AAIF and RMLIF. These bits are set according to the setting of the appropriate GIL bit in the CANGIM register.

The following bits are set regardless of the corresponding interrupt mask bits in the CANGIM register: MTOF*n*, WDIF*n*, BOIF*n*, TCOF*n*, WUIF*n*, EPIF*n*, AAIF*n*, RMLIF*n*, and WLIF*n*.

For any mailbox, the GMIFn bit is set only when the corresponding mailbox interrupt mask bit (in the CANMIM register) is set.

If all interrupt flags are cleared and a new interrupt flag is set the interrupt output line is activated when the corresponding interrupt mask bit is set. The interrupt line stays active until the interrupt flag is cleared by the CPU by writing a 1 to the appropriate bit or by clearing the interrupt-causing condition.

The GMIFx flags must be cleared by writing a 1 to the appropriate bit in the CANTA register or the CANRMP register (depending on mailbox configuration) and cannot be cleared in the CANGIFx register. After clearing one or more interrupt flags and one or more interrupt flags still set, a new interrupt is generated. The interrupt flags are cleared by writing a 1 to the corresponding bit location. If the GMIFx is set the Mailbox Interrupt Vector MIVx indicates the mailbox number of the mailbox that caused the setting of the GMIFx. In case more than one mailbox interrupt is pending, it always displays the highest mailbox interrupt vector assigned to that interrupt line.

www.ti.com

eCAN Registers

|       |          | Figure 12-2 | 0. Global Inte | rrupt Flag 0 R | Register (CAN | GIF0)  |        |
|-------|----------|-------------|----------------|----------------|---------------|--------|--------|
| 31    |          |             |                |                |               |        | 24     |
|       |          |             | Res            | erved          |               |        |        |
|       |          |             | R              | R-x            |               |        |        |
| 23    |          |             |                |                | 18            | 17     | 16     |
|       |          | Res         | erved          |                |               | MTOF0  | TCOF0  |
|       | R-0      | RC-0        |                |                |               |        |        |
| 15    | 14       | 13          | 12             | 11             | 10            | 9      | 8      |
| GMIF0 | AAIF0    | WDIF0       | WUIF0          | RMLIF0         | BOIF0         | EPIF0  | WLIF0  |
| R/W-0 | R-0      | RC-0        | RC-0           | R-0            | RC-0          | RC-0   | RC-0   |
| 7     |          | 5           | 4              | 3              | 2             | 1      | 0      |
|       | Reserved |             | MIV0.4         | MIV0.3         | MIV0.2        | MIV0.1 | MIV0.0 |
|       | R/W-0    |             | R-0            | R-0            | R-0           | R-0    | R-0    |

LEGEND: R/W = Read/Write; R = Read; C = Clear; -n = value after reset

### Figure 12-21. Global Interrupt Flag 1 Register (CANGIF1)

| 31    |          |       |        |        |        |        | 24     |
|-------|----------|-------|--------|--------|--------|--------|--------|
|       |          |       | Res    | erved  |        |        |        |
|       |          |       | F      | R-x    |        |        |        |
| 23    |          |       |        |        | 18     | 17     | 16     |
|       |          | Res   | erved  |        |        | MTOF1  | TCOF1  |
|       |          | F     | l-x    |        |        | R-0    | RC-0   |
| 15    | 14       | 13    | 12     | 11     | 10     | 9      | 8      |
| GMIF1 | AAIF1    | WDIF1 | WUIF1  | RMLIF1 | BOIF1  | EPIF1  | WLIF1  |
| R/W-0 | R-0      | RC-0  | RC-0   | R-0    | RC-0   | RC-0   | RC-0   |
| 7     |          | 5     | 4      | 3      | 2      | 1      | 0      |
|       | Reserved |       | MIV0.4 | MIV0.3 | MIV0.2 | MIV0.1 | MIV0.0 |
|       | R/W-0    |       | R-0    | R-0    | R-0    | R-0    | R-0    |

LEGEND: R/W = Read/Write; R = Read; C = Clear; -n = value after reset Note: eCAN only, reserved in the SCC

> **NOTE:** The following bit descriptions are applicable to both the CANGIF0 and CANGIF1 registers. For the following interrupt flags, whether they are set in the CANGIF0 or the CANGIF1 register is determined by the value of the GIL bit in the CANGIM register: TCOFn, AAIFn, WDIFn, WUIFn, RMLIFn, BOIFn, EPIFn, and WLIFn.

If GIL = 0, these flags are set in the CANGIF0 register; if GIL = 1, they are set in the CANGIF1 register.

Similarly, the choice of the CANGIF0 and CANGIF1 register for the MTOFn and GMIFn bits is determined by the MILn bit in the CANMIL register.

### Table 12-18. Global Interrupt Flag Registers (CANGIF0/CANGIF1) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                       |
|-------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved |       | Reserved. Reads are undefined and writes have no effect.                                                                                                                                                                          |
| 17    | MTOF0/1  |       | Mailbox time-out flag. This bit is not available in the SCC mode.                                                                                                                                                                 |
|       |          | 1     | One of the mailboxes did not transmit or receive a message within the specified time frame.                                                                                                                                       |
|       |          | 0     | No time out for the mailboxes occurred.                                                                                                                                                                                           |
|       |          |       | <b>Note:</b> Whether the MTOFn bit gets set in CANGIF0 or CANGIF1 depends on the value of MIL <i>n</i> . MTOFn gets cleared when TOSn is cleared. The TOSn bit will be cleared upon (eventual) successful transmission/reception. |

### Table 12-18. Global Interrupt Flag Registers (CANGIF0/CANGIF1) Field Descriptions (continued)

| Bit | Field            | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16  | TCOF0/1          |       | Time stamp counter overflow flag.                                                                                                                                                                                                                                                                                                                                                                          |
|     |                  | 1     | The MSB of the time stamp counter has changed from 0 to 1.                                                                                                                                                                                                                                                                                                                                                 |
|     |                  | 0     | The MSB of the time stamp counter is 0. That is, it has not changed from 0 to 1.                                                                                                                                                                                                                                                                                                                           |
| 15  | GMIF0/1          |       | Global mailbox interrupt flag. This bit is set only when the corresponding mailbox interrupt mask bit in the CANMIM register is set.                                                                                                                                                                                                                                                                       |
|     |                  | 1     | One of the mailboxes transmitted or received a message successfully.                                                                                                                                                                                                                                                                                                                                       |
|     |                  | 0     | No message has been transmitted or received.                                                                                                                                                                                                                                                                                                                                                               |
| 14  | AAIF0/1          |       | Abort-acknowledge interrupt flag                                                                                                                                                                                                                                                                                                                                                                           |
|     |                  | 1     | A send transmission request has been aborted.                                                                                                                                                                                                                                                                                                                                                              |
|     |                  | 0     | No transmission has been aborted.                                                                                                                                                                                                                                                                                                                                                                          |
|     |                  |       | Note: The AAIFn bit is cleared by clearing the set AAn bit.                                                                                                                                                                                                                                                                                                                                                |
| 13  | WDIF0/WDIF1      |       | Write-denied interrupt flag                                                                                                                                                                                                                                                                                                                                                                                |
|     |                  | 1     | The CPU write access to a mailbox was not successful. The WDIF interrupt is asserted when the identifier field of a mailbox is written to, while it is enabled. Before writing to the MSGID field of a MBX, it should be disabled. If you try this operation when the MBX is still enabled, the WDIF bit will be set and a CAN interrupt asserted.                                                         |
|     |                  | 0     | The CPU write access to the mailbox was successful.                                                                                                                                                                                                                                                                                                                                                        |
| 12  | WUIF0/WUIF1      |       | Wake-up interrupt flag                                                                                                                                                                                                                                                                                                                                                                                     |
|     |                  | 1     | During local power down, this flag indicates that the module has left sleep mode.                                                                                                                                                                                                                                                                                                                          |
|     |                  | 0     | The module is still in sleep mode or normal operation                                                                                                                                                                                                                                                                                                                                                      |
| 11  | RMLIF0/1         |       | Receive-message-lost interrupt flag                                                                                                                                                                                                                                                                                                                                                                        |
|     |                  | 1     | At least for one of the receive mailboxes, an overflow condition has occurred and the corresponding bit in the MILn register is cleared.                                                                                                                                                                                                                                                                   |
|     |                  | 0     | No message has been lost.                                                                                                                                                                                                                                                                                                                                                                                  |
|     |                  |       | Note: The RMLIFn bit is cleared by clearing the set RMPn bit.                                                                                                                                                                                                                                                                                                                                              |
| 10  | BOIF0/BOIF1      |       | Bus off interrupt flag                                                                                                                                                                                                                                                                                                                                                                                     |
|     |                  | 1     | The CAN module has entered bus-off mode.                                                                                                                                                                                                                                                                                                                                                                   |
|     |                  | 0     | The CAN module is still in bus-on mode.                                                                                                                                                                                                                                                                                                                                                                    |
| 9   | EPIF0/EPIF1      |       | Error passive interrupt flag                                                                                                                                                                                                                                                                                                                                                                               |
|     |                  | 1     | The CAN module has entered error-passive mode.                                                                                                                                                                                                                                                                                                                                                             |
|     |                  | 0     | The CAN module is not in error-passive mode.                                                                                                                                                                                                                                                                                                                                                               |
| 8   | WLIF0/WLIF1      |       | Warning level interrupt flag                                                                                                                                                                                                                                                                                                                                                                               |
|     |                  | 1     | At least one of the error counters has reached the warning level.                                                                                                                                                                                                                                                                                                                                          |
|     |                  | 0     | None of the error counters has reached the warning level.                                                                                                                                                                                                                                                                                                                                                  |
| 7:5 | Reserved         |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                                                                             |
| 4:0 | MIV0.4:0/MIV1.4: |       | Mailbox interrupt vector. Only bits 3:0 are available in SCC mode.                                                                                                                                                                                                                                                                                                                                         |
|     | 0                |       | This vector indicates the number of the mailbox that set the global mailbox interrupt flag. It keeps that vector until the appropriate MIFn bit is cleared or when a higher priority mailbox interrupt occurred. Then the highest interrupt vector is displayed, with mailbox 31 having the highest priority. In the SCC mode, mailbox 15 has the highest priority. Mailboxes 16 to 31 are not recognized. |
|     |                  |       | If no flag is set in the TA/RMP register and GMIF1 or GMIF0 also cleared, this value is undefined.                                                                                                                                                                                                                                                                                                         |

### 12.6.15.2 Global Interrupt Mask Register (CANGIM)

The set up for the interrupt mask register is the same as for the interrupt flag register. If a bit is set, the corresponding interrupt is enabled. This register is EALLOW protected.

eCAN Registers

| 31       |        |          |          |        |        | 18     | 17         | 16        |
|----------|--------|----------|----------|--------|--------|--------|------------|-----------|
|          |        |          | Reserved |        |        |        | MTOM       | TCO       |
|          |        |          | R-0      |        |        |        | R/WP-<br>0 | R/WI<br>0 |
| 15       | 14     | 13       | 12       | 11     | 10     | 9      | ł          | 8         |
| Reserved | AAIM   | WDIM     | WUIM     | RMLIM  | BOIM   | EPIM   | WI         | _IM       |
| R-0      | R/WP-0 | R/WP-0   | R/WP-0   | R/WP-0 | R/WP-0 | R/WP-0 | R/W        | VP-0      |
| 7        |        |          |          | 3      | 2      | 1      | (          | 0         |
|          |        | Reserved |          |        | GIL    | I1EN   | 101        | EN        |
|          |        | R-0      |          |        | R/WP-0 | R/WP-0 | R/W        | VP-0      |

LEGEND: R = Read; W = Write; WP = Write in EALLOW mode only; -*n* = value after reset

### Table 12-19. Global Interrupt Mask Register (CANGIM) Field Descriptions

| Bit   | Field    | Value | Description                                                                                   |
|-------|----------|-------|-----------------------------------------------------------------------------------------------|
| 31:18 | Reserved |       | Reads are undefined and writes have no effect.                                                |
| 17    | МТОМ     |       | Mailbox time-out interrupt mask                                                               |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 16    | тсом     |       | Time stamp counter overflow mask                                                              |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 15    | Reserved |       | Reads are undefined and writes have no effect.                                                |
| 14    | AAIM     |       | Abort Acknowledge Interrupt Mask.                                                             |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 13    | WDIM     |       | Write denied interrupt mask                                                                   |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 12    | WUIM     |       | Wake-up interrupt mask                                                                        |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 11    | RMLIM    |       | Received-message-lost interrupt mask                                                          |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 10    | BOIM     |       | Bus-off interrupt mask                                                                        |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 9     | EPIM     |       | Error-passive interrupt mask                                                                  |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 8     | WLIM     |       | Warning level interrupt mask                                                                  |
|       |          | 1     | Enabled                                                                                       |
|       |          | 0     | Disabled                                                                                      |
| 7:3   | Reserved |       | Reads are undefined and writes have no effect.                                                |
| 2     | GIL      |       | Global interrupt level for the interrupts TCOF, WDIF, WUIF, BOIF, EPIF, RMLIF, AAIF and WLIF. |
|       |          | 1     | All global interrupts are mapped to the ECAN1INT interrupt line.                              |
|       |          | 0     | All global interrupts are mapped to the ECAN0INT interrupt line.                              |



| Bit | Field | Value | Description                                                                                        |
|-----|-------|-------|----------------------------------------------------------------------------------------------------|
| 1   | I1EN  |       | Interrupt 1 enable                                                                                 |
|     |       | 1     | This bit globally enables all interrupts for the ECAN1INT line if the corresponding masks are set. |
|     |       | 0     | The ECAN1INT interrupt line is disabled.                                                           |
| 0   | IOEN  |       | Interrupt 0 enable                                                                                 |
|     |       | 1     | This bit globally enables all interrupts for the ECAN0INT line if the corresponding masks are set. |
|     |       | 0     | The ECAN0INT interrupt line is disabled.                                                           |

### Table 12-19. Global Interrupt Mask Register (CANGIM) Field Descriptions (continued)

The GMIF has no corresponding bit in the CANGIM because the mailboxes have individual mask bits in the CANMIM register.



~ 4

### 12.6.15.3 Mailbox Interrupt Mask Register (CANMIM)

There is one interrupt flag available for each mailbox. This can be a receive or a transmit interrupt depending on the configuration of the mailbox. This register is EALLOW protected.

### Figure 12-23. Mailbox Interrupt Mask Register (CANMIM)

| 31       | 0 |
|----------|---|
| MIM.31:0 |   |
| R/W-0    |   |

LEGEND: R/W = Read/Write; -n = value after reset

### Table 12-20. Mailbox Interrupt Mask Register (CANMIM) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                                                                |
|------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | MIM.31:0 |       | Mailbox interrupt mask. After power up all interrupt mask bits are cleared and the interrupts are disabled. These bits allow any mailbox interrupt to be masked individually.                                              |
|      |          | 1     | Mailbox interrupt is enabled. An interrupt is generated if a message has been transmitted successfully (in case of a transmit mailbox) or if a message has been received without any error (in case of a receive mailbox). |
|      |          | 0     | Mailbox interrupt is disabled.                                                                                                                                                                                             |

eCAN Registers



### 12.6.15.4 Mailbox Interrupt Level Register (CANMIL)

Each of the 32 mailboxes may initiate an interrupt on one of the two interrupt lines. Depending on the setting in the mailbox interrupt level register (CANMIL), the interrupt is generated on ECAN0INT (MILn = 0) or on line ECAN1INT (MIL[n] = 1).

### Figure 12-24. Mailbox Interrupt Level Register (CANMIL)

| 31       | 0 |
|----------|---|
| MIL.31:0 |   |
| R/W-0    |   |

LEGEND: R/W = Read/Write; -*n* = value after reset

### Table 12-21. Mailbox Interrupt Level Register (CANMIL) Field Descriptions

| Bit  | Field    | Value | Description                                                                                        |
|------|----------|-------|----------------------------------------------------------------------------------------------------|
| 31:0 | MIL.31:0 |       | Mailbox interrupt level. These bits allow any mailbox interrupt level to be selected individually. |
|      |          | 1     | The mailbox interrupt is generated on interrupt line 1.                                            |
|      |          | 0     | The mailbox interrupt is generated on interrupt line 0.                                            |



# 12.6.16 Overwrite Protection Control Register (CANOPC)

If there is an overflow condition for mailbox n (RMP[n] is set to 1 and a new receive message would fit for mailbox n), the new message is stored depending on the settings in the CANOPC register. If the corresponding bit OPC[n] is set to 1, the old message is protected against being overwritten by the new message; thus, the next mailboxes are checked for a matching ID. If no other mailbox is found, the message is lost without further notification. If the bit OPC[n] is cleared to 0, the old message is overwritten by the new one. This is notified by setting the receive message lost bit RML[n].

For read/write operations, only 32-bit access is supported.

### Figure 12-25. Overwrite Protection Control Register (CANOPC)

| 31       | 0 |
|----------|---|
| OPC.31:0 |   |
| R/W-0    |   |

LEGEND: R/W = Read/Write; -*n* = value after reset

### Table 12-22. Overwrite Protection Control Register (CANOPC) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                |
|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | OPC.31:0 |       | Overwrite protection control bits                                                                                                          |
|      |          | 1     | 1 If the bit OPC[ <i>n</i> ] is set to 1, an old message stored in that mailbox is protected against being overwritten by the new message. |
|      |          | 0     | 0 If the bit OPC[n] is not set, the old message can be overwritten by a new one.                                                           |



# 12.6.17 eCAN I/O Control Registers (CANTIOC, CANRIOC)

The CANTX and CANRX pins should be configured for CAN use. This is done using the CANTIOC and CANRIOC registers.

### Figure 12-26. TX I/O Control Register (CANTIOC)

| 31 |          |   |            |   |          | 16 |
|----|----------|---|------------|---|----------|----|
|    | Reserved |   |            |   |          |    |
|    | R-0      |   |            |   |          |    |
| 15 |          | 4 | 3          | 2 |          | 0  |
|    | Reserved |   | TXFU<br>NC |   | Reserved |    |
|    | R-0      |   | RWP-       |   |          |    |

LEGEND: RWP = Read in all modes, write in EALLOW-mode only; R = Read only; -n = value after reset

### Table 12-23. TX I/O Control Register (CANTIOC) Field Descriptions

| Bit  | Field    | Value | Description                                           |  |  |
|------|----------|-------|-------------------------------------------------------|--|--|
| 31:4 | Reserved |       | Reads are undefined and writes have no effect.        |  |  |
| 3    | TXFUNC   |       | bit must be set for CAN module function.              |  |  |
|      |          | 1     | The CANTX pin is used for the CAN transmit functions. |  |  |
|      |          | 0     | Reserved                                              |  |  |
| 2:0  | Reserved |       | Reserved                                              |  |  |



eCAN Registers

www.ti.com

2:0

Reserved

# Figure 12-27. RX I/O Control Register (CANRIOC)

| 31 | -        |   | -          |      | 16    |
|----|----------|---|------------|------|-------|
|    | Reserved |   |            |      |       |
|    | R-x      |   |            |      |       |
| 15 |          | 4 | 3          | 2    | 0     |
|    | Reserved |   | RXFU<br>NC | Rese | erved |
|    | R-0      |   | RWP-<br>0  |      |       |

LEGEND: RWP = Read in all modes, write in EALLOW-mode only; R = Read only; -n = value after reset; x = indeterminate

0

Reserved

Reserved

# Bit Field Value Description 31:4 Reserved Reads are undefined and writes have no effect. 3 RXFUNC This bit must be set for CAN module function. 1 The CANRX pin is used for the CAN receive functions.

### Table 12-24. RX I/O Control Register (CANRIOC) Field Descriptions



### 12.6.18 Timer Management Unit

Several functions are implemented in the eCAN to monitor the time when messages are transmitted/received. A separate state machine is included in the eCAN to handle the time-control functions. This state machine has lower priority when accessing the registers than the CAN state machine has. Therefore, the time-control functions may be delayed by other ongoing actions.

### 12.6.18.1 Time Stamp Functions

To get an indication of the time of reception or transmission of a message, a free-running 32-bit timer (TSC) is implemented in the module. Its content is written into the time stamp register of the corresponding mailbox (Message Object Time Stamp [MOTS]) when a received message is stored or a message has been transmitted.

The counter is driven from the bit clock of the CAN bus line. The timer is stopped during the initialization mode or if the module is in sleep or suspend mode. After power-up reset, the free-running counter is cleared.

The most significant bit of the TSC register is cleared by writing a 1 to TCC (CANMC.14). The TSC register can also be cleared when mailbox 16 transmitted or received (depending on the setting of CANMD.16 bit) a message successfully. This is enabled by setting the MBCC bit (CANMC.15). Therefore, it is possible to use mailbox 16 for global time synchronization of the network. The CPU can read and write the counter.

Overflow of the counter is detected by the TSC-counter-overflow-interrupt flag (TCOF*n*-CANGIF*n*.16). An overflow occurs when the highest bit of the TSC counter changes to 1. Therefore, the CPU has enough time to handle this situation.



### 12.6.18.1.1 Time-Stamp Counter Register (CANTSC)

This register holds the time-stamp counter value at any instant of time. This is a free-running 32-bit timer which is clocked by the bit clock of the CAN bus. For example, at a bit rate of 1 Mbps, CANTSC would increment every 1  $\mu$ s.

### Figure 12-28. Time-Stamp Counter Register (CANTSC)

| 31                                                                       | 0 |
|--------------------------------------------------------------------------|---|
| TSC31:0                                                                  |   |
| R/WP-0                                                                   |   |
| LEGEND D. Dead WD. White is EAULOW eachied and a she an eacher streament |   |

LEGEND: R = Read; WP = Write in EALLOW enabled mode only; -n = value after reset Note: eCAN mode only, reserved in the SCC

### Table 12-25. Time-Stamp Counter Register (CANTSC) Field Descriptions

| Bit  | Field   | Value | Description                                                                                                              |
|------|---------|-------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TSC31:0 |       | Time-stamp counter register. Value of the local network time counter used for the time-stamp and the time-out functions. |



### 12.6.18.1.2 Message Object Time Stamp Registers (MOTS)

This register holds the value of the TSC when the corresponding mailbox data was successfully transmitted or received. Each mailbox has its own MOTS register.

### Figure 12-29. Message Object Time Stamp Registers (MOTS)

| 31       | 0 |
|----------|---|
| MOTS31:0 |   |
| R/W-x    |   |

LEGEND: R/W = Read/Write; -n = value after reset; x = indeterminate

### Table 12-26. Message Object Time Stamp Registers (MOTS) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                           |
|------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | MOTS31:0 |       | Message object time stamp register. Value of the time stamp counter (TSC) when the message has been actually received or transmitted. |



### 12.6.18.2 Time-Out Functions

To ensure that all messages are sent or received within a predefined period, each mailbox has its own time-out register. If a message has not been sent or received by the time indicated in the time-out register and the corresponding bit TOC[n] is set in the TOC register, a flag is set in the time-out status register (TOS).

For transmit mailboxes the TOS[n] flag is cleared when the TOC[n] bit is cleared or when the corresponding TRS[n] bit is cleared, no matter whether due to successful transmission or abortion of the transmit request. For receive mailboxes, the TOS[n] flag is cleared when the corresponding TOC[n] bit is cleared.

The CPU can also clear the time-out status register flags by writing a 1 into the time-out status register.

The message object time-out registers (MOTO) are implemented as a RAM. The state machine scans all the MOTO registers and compares them to the TSC counter value. If the value in the TSC register is equal to or greater than the value in the time-out register, and the corresponding TRS bit (applies to transmit mailboxes only) is set, and the TOC[n] bit is set, the appropriate bit TOS[n] is set. Since all the time-out registers are scanned sequentially, there can be a delay before the TOS[n] bit is set.

### 12.6.18.2.1 Message-Object Time-Out Registers (MOTO)

This register holds the time-out value of the TSC by which the corresponding mailbox data should be successfully transmitted or received. Each mailbox has its own MOTO register.

### Figure 12-30. Message-Object Time-Out Registers (MOTO)

| 31 |          | 0 |
|----|----------|---|
|    | MOTO31:0 |   |
|    | R/W-x    |   |

LEGEND: R/W = Read/Write; -*n* = value after reset; x = indeterminate

### Table 12-27. Message-Object Time-Out Registers (MOTO) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                |
|------|----------|-------|----------------------------------------------------------------------------------------------------------------------------|
| 31:0 | MOTO31:0 |       | Message object time-out register. Limit-value of the time-stamp counter (TSC) to actually transmit or receive the message. |

### 12.6.18.2.2 Time-Out Control Register (CANTOC)

This register controls whether or not time-out functionality is enabled for a given mailbox.

### Figure 12-31. Time-Out Control Register (CANTOC)

| 31 | - |    | _     | - | - | 0 |
|----|---|----|-------|---|---|---|
|    |   | TO | C31:0 |   |   |   |
|    |   | R/ | W-0   |   |   |   |

LEGEND: R/W = Read/Write; -*n* = value after reset

| Bit  | Field   | Value | Description                                                                                                                                                                                                              |
|------|---------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TOC31:0 |       | Time-out control register                                                                                                                                                                                                |
|      |         | 1     | The TOC[ $n$ ] bit must be set by the CPU to enable the time-out function for mailbox $n$ . Before setting the TOC[ $n$ ] bit, the corresponding MOTO register should be loaded with the time-out value relative to TSC. |
|      |         | 0     | The time-out function is disabled. The TOS[n] flag is never set.                                                                                                                                                         |

### Table 12-28. Time-Out Control Register (CANTOC) Field Descriptions



# 12.6.18.2.3 Time-Out Status Register (CANTOS)

This register holds the status information of mailboxes that have timed out.

#### Figure 12-32. Time-Out Status Register (CANTOS)

| 31 0      |
|-----------|
| TOS31:0   |
| <br>R/C-0 |

LEGEND: R/C = Read/Clear; -*n* = value after reset

## Table 12-29. Time-Out Status Register (CANTOS) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                             |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TOS 31:0 |       | Time-out status register                                                                                                                                                                |
|      |          | 1     | Mailbox[ $n$ ] has timed out. The value in the TSC register is larger or equal to the value in the time-<br>out register that corresponds to mailbox $n$ and the TOC[ $n$ ] bit is set. |
|      |          | 0     | No time-out occurred or it is disabled for that mailbox.                                                                                                                                |

The TOS*n* bit is set when all three of the following conditions are met:

- 1. The TSC value is greater than or equal to the value in the time-out register (MOTOn).
- 2. The TOC*n* bit is set.
- 3. The TRS*n* bit is set.

The time-out registers are implemented as a RAM. The state machine scans all the time-out registers and compares them to the time stamp counter value. Since all the time out registers are scanned sequentially, it is possible that even though a transmit mailbox has timed out, the TOS*n* bit is not set. This can happen when the mailbox succeeded in transmitting and clearing the TRS*n* bit before the state machine scans the time-out register of that mailbox. This is true for the receive mailbox as well. In this case, the RMP*n* bit can be set to 1 by the time the state machine scans the time-out register of that mailbox. However, the receive mailbox probably did not receive the message before the time specified in the time-out register.

#### 12.6.18.3 Behavior/Usage of MTOF0/1 Bit in User Applications

The MTOF0/1 bit is automatically cleared by the CPK (along with the TOS*n* bit) upon transmission/reception by the mailbox, which asserted this flag in the first place. It can also be cleared by the user (via the CPU). On a time-out condition, the MTOF0/1 bit (and the TOS.*n* bit) is set. On an (eventual) successful communication, these bits are automatically cleared by the CPK. Following are the possible behaviors/usage for the MTOF0/1 bit:

- 1. Time-out condition occurs. Both MTOF0/1 bit and TOS.*n* bits are set. Communication is never successful; i.e., the frame was never transmitted (or received). An interrupt is asserted. Application handles the issue and eventually clears both MTOF0/1 bit and TOS.*n* bit.
- 2. Time-out condition occurs. Both MTOF0/1 bit and TOS.*n* bits are set. However, communication is eventually successful; i.e., the frame gets transmitted (or received). Both MTOF0/1 bit and TOS.*n* bits are cleared automatically by the CPK. An interrupt is still asserted because, the interrupt occurrence was recorded in the PIE module. When the ISR scans the GIF register, it doesn't see the MTOF0/1 bit set. This is the phantom interrupt scenario. Application merely returns to the main code.
- 3. Time-out condition occurs. Both MTOF0/1 bit and TOS.*n* bits are set. While executing the ISR pertaining to time-out, communication is successful. This situation must be handled carefully. The application should not re-transmit a mailbox if the mailbox is sent between the time the interrupt is asserted and the time the ISR is attempting to take corrective action. One way of doing this is to poll the TM/RM bits in the GSR register. These bits indicate if the CPK is currently transmitting/receiving. If that is the case, the application should wait till the communication is over and then check the TOS.*n* bit again. If the communication is still not successful, then the application should take the corrective action.



# 12.6.19 Mailbox Layout

The following four 32-bit registers comprise each mailbox:

- MSGID Stores the message ID
- MSGCTRL Defines number of bytes, transmission priority and remote frames
- CANMDL 4 bytes of data
- CANMDH 4 bytes of data

## 12.6.19.1 Message Identifier Register (MSGID)

This register contains the message ID and other control bits for a given mailbox.

| Figure 12-33. | Message | Identifier | Register | (MSGID) | Register |
|---------------|---------|------------|----------|---------|----------|
|               |         |            |          |         |          |

| 31    | 30    | 29    | 28 |          | 0 |
|-------|-------|-------|----|----------|---|
| IDE   | AME   | AAM   |    | ID[28:0] |   |
| R/W-x | R/W-x | R/W-x |    | R/W-x    |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset; x = indeterminateNote: This register can be written only when mailbox n is disabled (CANME[n] (CANME.31-0) = 0).

## Table 12-30. Message Identifier Register (MSGID) Field Descriptions

| Bit | Field | Value | Description                                                                                                                                                                                                                                  |
|-----|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | IDE   |       | Identifier extension bit. The characteristics of the IDE bit changes according to the value of the AMI bit.                                                                                                                                  |
|     |       |       | When AMI = 1:                                                                                                                                                                                                                                |
|     |       |       | <ol> <li>The IDE bit of the receive mailbox is a "don't care." The IDE bit of the receive mailbox is<br/>overwritten by the IDE bit of the transmitted message.</li> </ol>                                                                   |
|     |       |       | 2. The filtering criterion must be satisfied in order to receive a message.                                                                                                                                                                  |
|     |       |       | <ol> <li>The number of bits to be compared is a function of the value of the IDE bit of the transmitted<br/>message.</li> </ol>                                                                                                              |
|     |       |       | When AMI = 0:                                                                                                                                                                                                                                |
|     |       |       | 1. The IDE bit of the receive mailbox determines the number of bits to be compared.                                                                                                                                                          |
|     |       |       | 2. Filtering is not applicable. The MSGIDs must match bit-for-bit in order to receive a message.                                                                                                                                             |
|     |       |       | When AMI = 1:                                                                                                                                                                                                                                |
|     |       |       | IDE = 1: The RECEIVED message had an extended identifier                                                                                                                                                                                     |
|     |       |       | IDE = 0: The RECEIVED message had a standard identifier                                                                                                                                                                                      |
|     |       |       | When AMI = 0:                                                                                                                                                                                                                                |
|     |       |       | IDE = 1: The message TO BE RECEIVED must have an extended identifier                                                                                                                                                                         |
|     |       |       | IDE = 0: The message TO BE RECEIVED must have a standard identifier.                                                                                                                                                                         |
| 30  | AME   |       | Acceptance mask enable bit. AME is only used for receive mailboxes. It must not be set for automatic reply $(AAM[n]=1, CANMD[n]=0)$ mailboxes, otherwise the mailbox behavior is undefined. This bit is not modified by a message reception. |
|     |       | 1     | The corresponding acceptance mask is used.                                                                                                                                                                                                   |
|     |       | 0     | No acceptance mask is used, all identifier bits must match to receive the message                                                                                                                                                            |
| 29  | AAM   |       | Auto answer mode bit. This bit is only valid for message mailboxes configured as transmit. For receive mailboxes, this bit has no effect: the mailbox is always configured for normal receive operation.                                     |
|     |       |       | This bit is not modified by a message reception.                                                                                                                                                                                             |
|     |       | 1     | Auto answer mode. If a matching remote request is received, the CAN module answers to the remote request by sending the contents of the mailbox.                                                                                             |
|     |       | 0     | Normal transmit mode. The mailbox does not reply to remote requests. The reception of a remote request frame has no effect on the message mailbox.                                                                                           |



| Bit  | Field    | Value | Description                                                                                                                                                |
|------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:0 | ID[28:0] |       | Message identifier                                                                                                                                         |
|      |          | 1     | In standard identifier mode, if the IDE bit (MSGID.31) = 0, the message identifier is stored in bits ID.28:18. In this case, bits ID.17:0 have no meaning. |
|      |          | 0     | In extended identifier mode, if the IDE bit (MSGID.31) = 1, the message identifier is stored in bits ID.28:0.                                              |

Table 12-30. Message Identifier Register (MSGID) Field Descriptions (continued)

## 12.6.19.2 CPU Mailbox Access

Write accesses to the identifier can only be accomplished when the mailbox is disabled (CANME[n] (CANME.31-0) = 0). During access to the data field, it is critical that the data does not change while the CAN module is reading it. Hence, a write access to the data field is disabled for a receive mailbox.

For send mailboxes, an access is usually denied if the TRS (TRS.31-0) or the TRR (TRR.31-0) flag is set. In these cases, an interrupt can be asserted. A way to access those mailboxes is to set CDR (MC.8) before accessing the mailbox data.

After the CPU access is finished, the CPU must clear the CDR flag by writing a 0 to it. The CAN module checks for that flag before and after reading the mailbox. If the CDR flag is set during those checks, the CAN module does not transmit the message but continues to look for other transmit requests. The setting of the CDR flag also stops the write-denied interrupt (WDI) from being asserted.



#### 12.6.19.3 Message-Control Register (MSGCTRL)

For a transmit mailbox, this register specifies the number of bytes to be transmitted and the transmission priority. It also specifies the remote-frame operation.

**NOTE:** As part of the CAN module initialization process, all the bits of the MSGCTRL*n* registers must first be initialized to zero before proceeding to initialize the various bit fields to the desired values.

|    | Figure 12-34. Message-Control Register (MSGCTRL) |    |      |   |    |          |   |      |   |      |    |
|----|--------------------------------------------------|----|------|---|----|----------|---|------|---|------|----|
| 31 |                                                  |    |      |   |    |          |   |      |   |      | 16 |
|    | Reserved                                         |    |      |   |    |          |   |      |   |      |    |
|    |                                                  |    |      | R | -0 |          |   |      |   |      |    |
| 15 | 13                                               | 12 |      | 8 | 7  |          | 5 | 4    | 3 |      | 0  |
| Re | served                                           |    | TPL  |   |    | Reserved |   | RTR  |   | DLC  |    |
|    | R-0                                              |    | RW-x |   |    | R-0      |   | RW-x |   | RW-x |    |

LEGEND: RW = Read any time, write when mailbox is disabled or configured for transmission; -n = value after reset; x = indeterminate Note: The register MSGCTRL(*n*) can only be written if mailbox *n* is configured for transmission (CANMD[*n*] (CANMD.31-0)=0) or if the mailbox is disabled (CANME[*n*] (CANME.31-0) =0).

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                |  |  |  |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:13 | Reserved |       | Reserved                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 12:8  | TPL.4:0  |       | Transmit-priority level. This 5-bit field defines the priority of this mailbox as compared to the other 31 mailboxes. The highest number has the highest priority. When two mailboxes have the same priority, the one with the higher mailbox number is transmitted. TPL applies only for transmit mailboxes. TPL is not used in SCC-mode. |  |  |  |
| 7:5   | Reserved |       | Reserved                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 4     | 4 RTR R  |       | Remote-transmission-request bit                                                                                                                                                                                                                                                                                                            |  |  |  |
|       |          | 1     | For receive mailbox: If the TRS flag is set, a remote frame is transmitted and the corresponding data frame is received in the same mailbox. Once the remote frame is sent, the TRS bit of the mailbox is cleared by CAN.                                                                                                                  |  |  |  |
|       |          |       | For transmit mailbox: If the TRS flag is set, a remote frame is transmitted, but the corresponding data frame has to be received in another mailbox.                                                                                                                                                                                       |  |  |  |
|       |          | 0     | No remote frame is requested.                                                                                                                                                                                                                                                                                                              |  |  |  |
| 3:0   | DLC 3:0  |       | Data-length code. The number in these bits determines how many data bytes are sent or received Valid value range is from 0 to 8. Values from 9 to 15 are not allowed.                                                                                                                                                                      |  |  |  |

# Table 12-31. Message-Control Register (MSGCTRL) Field Descriptions

## 12.6.19.4 Message Data Registers (CANMDL, CANMDH)

Eight bytes of the mailbox are used to store the data field of a CAN message. The setting of DBO (MC.10) determines the ordering of stored data. The data is transmitted or received from the CAN bus, starting with byte 0.

- When DBO (MC.10) = 1, the data is stored or read starting with the least significant byte of the CANMDL register and ending with the most significant byte of the CANMDH register.
- When DBO (MC.10) = 0, the data is stored or read starting with the most significant byte of the CANMDL register and ending with the least significant byte of the CANMDH register.

The registers CANMDL(*n*) and CANMDH(*n*) can be written only if mailbox *n* is configured for transmission (CANMD[*n*] (CANMD.31-0)=0) or the mailbox is disabled (CANME[*n*] (CANME.31-0)=0). If TRS[*n*] (TRS.31-0)=1, the registers CANMDL(*n*) and CANMDH(*n*) cannot be written, unless CDR (MC.8)=1, with MBNR (MC.4-0) set to *n*. These settings also apply for a message object configured in reply mode (AAM (MSGID.29)=1).

| 31 | 24 23              | 16 15                              | 8                         | 7             | ( |
|----|--------------------|------------------------------------|---------------------------|---------------|---|
|    | Byte 0             | Byte 1                             | Byte 2                    | Byte 3        |   |
|    | Figure 12          | -36. Message-Data-High R           | egister With DBO = 0      | (CANMDH)      |   |
| 51 | 24 23              | 16 15                              | 8                         | 7             | ( |
|    | Byte 4             | Byte 5                             | Byte 6                    | Byte 7        |   |
|    |                    |                                    |                           |               |   |
|    |                    |                                    |                           |               |   |
|    | Figure 12          | 2-37. Message-Data-Low R           | egister With DBO = 1      | (CANMDL)      |   |
| 31 | Figure 12<br>24 23 | 2-37. Message-Data-Low Ro<br>16 15 | egister With DBO = 1<br>8 | (CANMDL)<br>7 | ( |

|    | Figu   | ire 12-38. Message-Data-ł | ligh Register Witl | h DBO = 1 | (CANMDH) |   |
|----|--------|---------------------------|--------------------|-----------|----------|---|
| 31 | 24     | 23 1                      | 6 15               | 8         | 7        | 0 |
|    | Byte 7 | Byte 6                    | Byte 5             |           | Byte 4   |   |

**NOTE:** The data field beyond the valid received data is modified by any message reception and is indeterminate.



eCAN Registers

www.ti.com

#### 12.6.20 Acceptance Filter

The identifier of the incoming message is first compared to the message identifier of the mailbox (which is stored in the mailbox). Then, the appropriate acceptance mask is used to mask out the bits of the identifier that should not be compared.

In the SCC-compatible mode, the global acceptance mask (GAM) is used for the mailboxes 6 to 15. An incoming message is stored in the highest numbered mailbox with a matching identifier. If there is no matching identifier in mailboxes 15 to 6, the incoming message is compared to the identifier stored in mailboxes 5 to 3 and then 2 to 0.

The mailboxes 5 to 3 use the local-acceptance mask LAM(3) of the SCC registers. The mailboxes 2 to 0 use the local-acceptance mask LAM(0) of the SCC registers. For specific uses, see Figure 12-39.

To modify the global acceptance mask register (CANGAM) and the two local-acceptance mask registers of the SCC, the CAN module must be set in the initialization mode (see Section 3.1).

Each of the 32 mailboxes of the eCAN has its own local-acceptance mask LAM(0) to LAM(31). There is no global-acceptance mask in the eCAN.

The selection of the mask to be used for the comparison depends on which mode (SCC or eCAN) is used.

#### 12.6.20.1 Local-Acceptance Masks (CANLAM)

The local-acceptance filtering allows the user to locally mask (don't care) any identifier bits of the incoming message.

In the SCC, the local-acceptance-mask register LAM(0) is used for mailboxes 2 to 0. The localacceptance-mask register LAM(3) is used for mailboxes 5 to 3. For the mailboxes 6 to 15, the globalacceptance-mask (CANGAM) register is used.

After a hardware or a software reset of the SCC module, CANGAM is reset to zero. After a reset of the eCAN, the LAM registers are not modified.

In the eCAN, each mailbox (0 to 31) has its own mask register, LAM(0) to LAM(31). An incoming message is stored in the highest numbered mailbox with a matching identifier.



|       | Figure 12-39. Local-Acceptance-Mask Register (LAMn) |       |    |                      |    |  |  |  |
|-------|-----------------------------------------------------|-------|----|----------------------|----|--|--|--|
| 31    | 30                                                  | 29    | 28 |                      | 16 |  |  |  |
| LAMI  | Rese                                                | erved |    | LAM <i>n</i> [28:16] |    |  |  |  |
| R/W-0 | RΛ                                                  | N-0   |    | R/W-0                |    |  |  |  |
| 15    |                                                     |       |    |                      | 0  |  |  |  |
|       |                                                     |       |    | LAM <i>n</i> [15:0]  |    |  |  |  |
|       |                                                     |       |    | R/W-0                |    |  |  |  |

LEGEND: R/W = Read/Write; -*n* = value after reset

#### Table 12-32. Local-Acceptance-Mask Register (LAMn) Field Descriptions

| Bit     | Field     | Value | Description                                                                                                                                                                                                                                                                                                                                          |
|---------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 LAMI |           |       | Local-acceptance-mask identifier extension bit                                                                                                                                                                                                                                                                                                       |
|         |           | 1     | Standard and extended frames can be received. In case of an extended frame, all 29 bits of the identifier are stored in the mailbox and all 29 bits of the local-acceptance mask register are used for the filter. In case of a standard frame, only the first eleven bits (bits 28 to 18) of the identifier and the local-acceptance mask are used. |
|         |           | 0     | The identifier extension bit stored in the mailbox determines which messages shall be received.                                                                                                                                                                                                                                                      |
| 30:29   | Reserved  |       | Reads are undefined and writes have no effect.                                                                                                                                                                                                                                                                                                       |
| 28:0    | LAM[28:0] |       | These bits enable the masking of any identifier bit of an incoming message.                                                                                                                                                                                                                                                                          |
|         |           | 1     | Accept a 0 or a 1 (don't care) for the corresponding bit of the received identifier.                                                                                                                                                                                                                                                                 |
|         |           | 0     | Received identifier bit value must match the corresponding identifier bit of the MSGID register.                                                                                                                                                                                                                                                     |

You can locally mask any identifier bits of the incoming message. A 1 value means "don't care" or accept either a 0 or 1 for that bit position. A 0 value means that the incoming bit value must match identically to the corresponding bit in the message identifier.

If the local-acceptance mask identifier extension bit is set (LAMI =  $1 \Rightarrow$  don't care) standard and extended frames can be received. An extended frame uses all 29 bits of the identifier stored in the mailbox and all 29 bits of local-acceptance mask register for the filter. For a standard frame only the first eleven bits (bit 28 to 18) of the identifier and the local-acceptance mask are used.

If the local-acceptance mask identifier extension bit is reset (LAMI = 0), the identifier extension bit stored in the mailbox determines the messages that are received.

# 12.7 eCAN Configuration

This section explains the process of initialization and describes the procedures to configure the eCAN module.

# 12.7.1 CAN Module Initialization

The CAN module must be initialized before the utilization. Initialization is only possible if the module is in initialization mode. Figure 12-40 is a flow chart showing the process.

Programming CCR (CANMC.12) = 1 sets the initialization mode. The initialization can be performed only when CCE (CANES.4) = 1. Afterwards, the configuration registers can be written.

SCC mode only:

In order to modify the global acceptance mask register (CANGAM) and the two local acceptance mask registers [LAM(0) and LAM(3)], the CAN module also must be set in the initialization mode.

The module is activated again by programming CCR(CANMC.12) = 0.

After hardware reset, the initialization mode is active.

**NOTE:** If the CANBTC register is programmed with a zero value, or left with the initial value, the CAN module never leaves the initialization mode, i.e. CCE (CANES.4) bit remains at 1 when clearing the CCR bit.







**NOTE:** The transition between initialization mode and normal mode and vice-versa is performed in synchronization with the CAN network. That is, the CAN controller waits until it detects a bus idle sequence (= 11 recessive bits) before it changes the mode. In the event of a stuck-to-dominant bus error, the CAN controller cannot detect a bus-idle condition and therefore is unable to perform a mode transition.

# 12.7.1.1 CAN Bit-Timing Configuration

The CAN protocol specification partitions the nominal bit time into four different time segments:

**SYNC\_SEG:** This part of bit time is used to synchronize the various nodes on the bus. An edge is expected to lie within this segment. This segment is always 1 TIME QUANTUM (TQ).

**PROP\_SEG:** This part of the bit time is used to compensate for the physical delay times within the network. It is twice the sum of the signal's propagation 'time on the bus line, the input comparator delay, and the output driver delay. This segment is programmable from 1 to 8 TIME QUANTA (TQ).

**PHASE\_SEG1:** This phase is used to compensate for positive edge phase error. This segment is programmable from 1 to 8 TIME QUANTA (TQ) and can be lengthened by resynchronization.

**PHASE\_SEG2:** This phase is used to compensate for negative edge phase error. This segment is programmable from 2 to 8 TIME QUANTA (TQ) and can be shortened by resynchronization.

In the eCAN module, the length of a bit on the CAN bus is determined by the parameters TSEG1 (BTC.6-3), TSEG2 (BTC.2-0), and BRP (BTC.23.16).

TSEG1 combines the two time segments PROP\_SEG and PHASE\_SEG1 as defined by the CAN protocol. TSEG2 defines the length of the time segment PHASE\_SEG2.

IPT (information processing time) corresponds to the time necessary for the processing of the bit read. IPT corresponds to two units of TQ.

The following bit timing rules must be fulfilled when determining the bit segment values:

TEXAS INSTRUMENTS

www.ti.com

- TSEG1(min)  $\geq$  TSEG2
- IPT  $\leq$  TSEG1  $\leq$  16 TQ
- IPT  $\leq$  TSEG2  $\leq$  8 TQ
- IPT = 3/BRP (the resulting IPT has to be rounded up to the next integer value)
- 1 TQ ≤ SJW min[4 TQ, TSEG2] (SJW = Synchronization jump width)
- To utilize three-time sampling mode,  $BRP \ge 5$  has to be selected





A TSEG1 can be lengthened or TSEG2 shortened by the SJW

# 12.7.1.2 CAN Bit Rate Calculation

Bit-rate is calculated in bits per second as follows:

Bit rate = 
$$\frac{SYSCLKOUT/2}{BRP \times Bit Time}$$

Where bit-time is the number of time quanta (TQ) per bit. SYSCLKOUT is the CAN module system clock frequency, which is the same as the CPU clock frequency. BRP is the value of  $BRP_{reg} + 1$  (CANBTC.23-16).

Bit-time is defined as follows: Bit-time =  $(TSEG1_{reg} + 1) + (TSEG2_{reg} + 1) + 1$ 

In the above equation TESG1<sub>reg</sub> and TSEG2<sub>reg</sub> represent the actual values written in the corresponding fields in the CANBTC register. The parameters TSEG1<sub>reg</sub>, TSEG2r<sub>eg</sub>, SJW<sub>reg</sub>, and BRP<sub>reg</sub> are automatically enhanced by 1 when the CAN module accesses these parameters. TSEG1, TSEG2 and SJW, represent the values as applicable per Figure 12-41.

Bit-time = TSEG1 + TSEG2 + 1

# 12.7.1.3 Bit Configuration Parameters for 30-MHz CAN Clock

This section provides example values for the CANBTC bit fields for various CAN module clocks, bit rates and sampling points. Note that these values are for illustrative purposes only. In a real-world application, the propagation delay introduced by various entities such as the network cable, transceivers/ isolators must be taken into account before choosing the timing parameters.

Table 12-33 shows how the  $BRP_{reg}$  field may be changed to achieve different bit rates with a BT of 15 for an 80% SP.



| CAN Bus Speed | BRP                  | CAN Module Clock |  |
|---------------|----------------------|------------------|--|
| 1 Mbps        | $BRP_{reg} + 1 = 2$  | 15 MHz           |  |
| 500 kbps      | $BRP_{reg} + 1 = 4$  | 7.5 MHz          |  |
| 250 kbps      | $BRP_{reg} + 1 = 8$  | 3.75 MHz         |  |
| 125 kbps      | $BRP_{reg} + 1 = 16$ | 1.875 MHz        |  |
| 100 kbps      | $BRP_{reg} + 1 = 20$ | 1.5 MHz          |  |
| 50 kbps       | $BRP_{reg} + 1 = 40$ | 0.75 MHz         |  |

Table 12-34 shows how to achieve different sampling points with a BT of 15.

| TSEG1 <sub>reg</sub> | TSEG2 <sub>reg</sub> | SP  |
|----------------------|----------------------|-----|
| 10                   | 2                    | 80% |
| 9                    | 3                    | 73% |
| 8                    | 4                    | 66% |
| 7                    | 5                    | 60% |

Table 12-35 shows how  $BRP_{reg}$  field may be changed to achieve different bit rates with a BT of 10 for an 80% sampling point.

| CAN Bus Speed | BRP                  | CAN Module Clock |  |
|---------------|----------------------|------------------|--|
| 1 Mbps        | $BRP_{reg} + 1 = 3$  | 10 MHz           |  |
| 500 kbps      | $BRP_{reg} + 1 = 6$  | 5 MHz            |  |
| 250 kbps      | $BRP_{reg} + 1 = 12$ | 2.5 MHz          |  |
| 125 kbps      | $BRP_{reg} + 1 = 24$ | 1.25 MHz         |  |
| 100 kbps      | $BRP_{reg} + 1 = 30$ | 1 MHz            |  |
| 50 kbps       | $BRP_{reg} + 1 = 60$ | 0.5 MHz          |  |

**NOTE:** For a SYSCLKOUT of 60 MHz, the lowest bit-rate that can be achieved is 4.687 kbps.

# 12.7.1.4 EALLOW Protection

To protect against inadvertent modification, some critical registers/bits of the eCAN module are EALLOW protected. These registers/bits can be changed only if the EALLOW protection has been disabled. Following are the registers/ bits that are EALLOW protected in the eCAN module:

- CANMC[15..9] & MCR[7..6]
- CANBTC
- CANGIM
- MIM[31..0]
- TSC[31..0]
- IOCONT1[3]
- IOCONT2[3]

# 12.7.2 Steps to Configure eCAN

**NOTE:** This sequence must be done with EALLOW enabled.

The following steps must be performed to configure the eCAN for operation:

- Step 1. Enable clock to the CAN module.
- Step 2. Set the CANTX and the CANRX pins to CAN functions:
  - (a) Write CANTIOC.3:0 = 0x08
  - (b) Write CANRIOC.3:0 = 0x08
- Step 3. After a reset, bit CCR (CANMC.12) and bit CCE (CANES.4) are set to 1. This allows the user to configure the bit-timing configuration register (CANBTC). If the CCE bit is set (CANES.4 = 1), proceed to next step; otherwise, set the CCR bit (CANMC.12 = 1) and wait until CCE bit is set (CANES.4 = 1).
- Step 4. Program the CANBTC register with the appropriate timing values. Make sure that the values TSEG1 and TSEG2 are not 0. If they are 0, the module does not leave the initialization mode.
- Step 5. For the SCC, program the acceptance masks now. For example: Write LAM(3) = 0x3C0000
- Step 6. Program the master control register (CANMC) as follows:
  - (a) Clear CCR (CANMC.12) = 0
  - (b) Clear PDR (CANMC.11) = 0
  - (c) Clear DBO (CANMC.10) = 0
  - (d) Clear WUBA (CANMC.9)= 0
  - (e) Clear CDR (CANMC.8) = 0
  - (f) Clear ABO (CANMC.7) = 0
  - (g) Clear STM (CANMC.6) = 0
  - (h) Clear SRES (CANMC.5) = 0
  - (i) Clear MBNR (CANMC.4-0) = 0
- Step 7. Initialize all bits of MSGCTRLn registers to zero.
- Step 8. Verify the CCE bit is cleared (CANES.4 = 0), indicating that the CAN module has been configured.

This completes the setup for the basic functionality.



eCAN Configuration

#### 12.7.2.1 Configuring a Mailbox for Transmit

To transmit a message, the following steps need to be performed (in this example, for mailbox 1):

1. Clear the appropriate bit in the CANTRS register to 0:

Clear CANTRS.1 = 0 (Writing a 0 to TRS has no effect; instead, set TRR.1 and wait until TRS.1 clears.) If the RTR bit is set, the TRS bit can send a remote frame. Once the remote frame is sent, the TRS bit of the mailbox is cleared by the CAN module. The same node can be used to request a data frame from another node.

- Disable the mailbox by clearing the corresponding bit in the mailbox enable (CANME) register. Clear CANME.filter1 = 0
- 3. Load the message identifier (MSGID) register of the mailbox. Clear the AME (MSGID.30) and AAM (MSGID.29) bits for a normal send mailbox (MSGID.30 = 0 and MSGID.29 = 0). This register is usually not modified during operation. It can only be modified when the mailbox is disabled. For example:
  - (a) Write MSGID(1) = 0x15AC0000
  - (b) Write the data length into the DLC field of the message control field register (MSGCTRL.3:0). The RTR flag is usually cleared (MSGCTRL.4 = 0).
  - (c) Set the mailbox direction by clearing the corresponding bit in the CANMD register.
  - (d) Clear CANMD.1 = 0
- 4. Set the mailbox enable by setting the corresponding bit in the CANME register

Set CANME.1 = 1

This configures mailbox 1 for transmit mode.

# 12.7.2.2 Transmitting a Message

To start a transmission (in this example, for mailbox:

- 1. Write the message data into the mailbox data field.
  - (a) Since DBO (MC.10) is set to zero in the configuration section and MSGCTRL(1) is set to 2, the data are stored in the 2 MSBytes of CANMDL(1).

(b) Write CANMDL(1) = xxxx0000h

- 2. Set the corresponding flag in the transmit request register (CANTRS.1 = 1) to start the transmission of the message. The CAN module now handles the complete transmission of the CAN message.
- 3. Wait until the transmit-acknowledge flag of the corresponding mailbox is set (TA.1 = 1). After a successful transmission, this flag is set by the CAN module.
- 4. The TRS flag is reset to 0 by the module after a successful or aborted transmission (TRS.1 = 0).
- 5. The transmit acknowledge must be cleared for the next transmission (from the same mailbox).
  - (a) Set TA.1 = 1
  - (b) Wait until read TA.1 is 0
- 6. To transmit another message in the same mailbox, the mailbox RAM data must be updated. Setting the TRS.1 flag starts the next transmission. Writing to the mailbox RAM can be half-word (16 bits) or full word (32 bits) but the module always returns 32-bit from even boundary. The CPU must accept all the 32 bits or part of it.

# 12.7.2.3 Configuring Mailboxes for Receive

To configure a mailbox to receive messages, the following steps must be performed (in this example, mailbox 3):

- Disable the mailbox by clearing the corresponding bit in the mailbox enable (CANME) register. Clear CANME.3 = 0
- Write the selected identifier into the corresponding MSGID register. The identifier extension bit must be configured to fit the expected identifier. If the acceptance mask is used, the acceptance mask enable (AME) bit must be set (MSGID.30 = 1). For example: Write MSGID(3) = 0x4f780000

- 3. If the AME bit is set to 1, the corresponding acceptance mask must be programmed. Write LAM(3) = 0x03c0000.
- 4. Configure the mailbox as a receive mailbox by setting the corresponding flag in the mailbox direction register (CANMD.3 = 1). Make sure no other bits in this register are affected by this operation.
- 5. If data in the mailbox is to be protected, the overwrite protection control register (CANOPC) should be programmed now. This protection is useful if no message must be lost. If OPC is set, the software has to make sure that an additional mailbox (buffer mailbox) is configured to store 'overflow' messages. Otherwise messages can be lost without notification. Write OPC.3 = 1
- 6. Enable the mailbox by setting the appropriate flag in the mailbox enable register (CANME). This should be done by reading CANME, and writing back (CANME |= 0x0008) to make sure no other flag has changed accidentally.

The object is now configured for the receive mode. Any incoming message for that object is handled automatically.

# 12.7.2.4 Receiving a Message

This example uses mailbox 3. When a message is received, the corresponding flag in the receive message pending register (CANRMP) is set to 1 and an interrupt can be initiated. The CPU can then read the message from the mailbox RAM. Before the CPU reads the message from the mailbox, it should first clear the RMP bit (RMP.3 = 1). The CPU should also check the receive message lost flag RML.3 = 1. Depending on the application, the CPU has to decide how to handle this situation.

After reading the data, the CPU needs to check that the RMP bit has not been set again by the module. If the RMP bit has been set to 1, the data may have been corrupted. The CPU needs to read the data again because a new message was received while the CPU was reading the old one.

## 12.7.2.5 Handling of Overload Situations

If the CPU is not able to handle important messages fast enough, it may be advisable to configure more than one mailbox for that identifier. Here is an example where the objects 3, 4, and 5 have the same identifier and share the same mask. For the SCC, the mask is LAM(3). For the eCAN, each object has its own LAM: LAM(3), LAM(4), and LAM(5), all of which need to be programmed with the same value.

To make sure that no message is lost, set the OPC flag for objects 4 and 5, which prevents unread messages from being overwritten. If the CAN module must store a received message, it first checks mailbox 5. If the mailbox is empty, the message is stored there. If the RMP flag of object 5 is set (mailbox occupied), the CAN module checks the condition of mailbox 4. If that mailbox is also busy, the module checks in mailbox 3 and stores the message there since the OPC flag is not set for mailbox 3. If mailbox 3 contents have not been previously read, it sets the RML flag of object 3, which can initiate an interrupt.

It is also advisable to have object 4 generate an interrupt telling the CPU to read mailboxes 4 and 5 at once. This technique is also useful for messages that require more than 8 bytes of data (i.e., more than one message). In this case, all data needed for the message can be collected in the mailboxes and be read at once.

# 12.7.3 Handling of Remote Frame Mailboxes

There are two functions for remote frame handling. One is a request by the module for data from another node, the other is a request by another node for data that the module needs to answer.

# 12.7.3.1 Requesting Data From Another Node

In order to request data from another node, the object is configured as receive mailbox. Using object 3 for this example, the CPU needs to do the following:

- Set the RTR bit in the message control field register (CANMSGCTRL) to 1. Write MSGCTRL(3) = 0x12
- Write the correct identifier into the message identifier register (MSGID). Write MSGID(3) = 0x4F780000



eCAN Configuration

www.ti.com

- Set the CANTRS flag for that mailbox. Since the mailbox is configured as receive, it only sends a remote request message to the other node. Set CANTRS.3 = 1
- The module stores the answer in that mailbox and sets the RMP bit when it is received. This action can initiate an interrupt. Also, make sure no other mailbox has the same ID. Wait for RMP.3 = 1
- 5. Read the received message.

# 12.7.3.2 Answering a Remote Request

- 1. Configure the object as as a transmit mailbox.
- Set the auto answer mode (AAM) (MSGID.29) bit in the MSGID register before the mailbox is enabled. MSGID(1) = 0x35AC0000
- Update the data field. MDL, MDH(1) = xxxxxxxh
- 4. Enable the mailbox by setting the CANME flag to 1.
  - CANME.1 = 1

When a remote request is received from another node, the TRS flag is set automatically and the data is transmitted to that node. The identifier of the received message and the transmitted message are the same.

After transmission of the data, the TA flag is set. The CPU can then update the data. Wait for TA.1 = 1

# 12.7.3.3 Updating the Data Field

To update the data of an object that is configured in auto answer mode, the following steps need to be performed. This sequence can also be used to update the data of an object configured in normal transmission with TRS flag set.

- Set the change data request (CDR) (MC.8) bit and the mailbox number (MBNR) of that object in the master control register (CANMC). This tells the CAN module that the CPU wants to change the data field. For example, for object 1: Write MC = 0x0000101
- 2. Write the message data into the mailbox data register. For example: Write CANMDL(1) = xxxx0000h
- 3. Clear the CDR bit (MC.8) to enable the object. Write MC = 0x00000000

# 12.7.4 Interrupts

There are two different types of interrupts. One type of interrupt is a mailbox related interrupt, for example, the receive-message-pending interrupt or the abort-acknowledge interrupt. The other type of interrupt is a system interrupt that handles errors or system-related interrupt sources, for example, the error-passive interrupt or the wake-up interrupt. See Figure 12-42.

The following events can initiate one of the two interrupts:

- Mailbox interrupts
  - Message reception interrupt: a message was received
  - Message transmission interrupt: a message was transmitted successfully
  - Abort-acknowledge interrupt: a pending transmission was aborted
  - Received-message-lost interrupt: an old message was overwritten by a new one (before the old message was read)
  - Mailbox timeout interrupt (eCAN mode only): one of the messages was not transmitted or received within a predefined time frame
- System interrupts
  - Write-denied interrupt: the CPU tried to write to a mailbox but was not allowed to



- Wake-up interrupt: this interrupt is generated after a wake up
- Bus-off interrupt: the CAN module enters the bus-off state
- Error-passive interrupt: the CAN module enters the error-passive mode
- Warning level interrupt: one or both error counters are greater than or equal to 96
- Time-stamp counter overflow interrupt (eCAN only): the time-stamp counter had an overflow



Figure 12-42. Interrupts Scheme



#### 12.7.4.1 Interrupts Scheme

The interrupt flags are set if the corresponding interrupt condition occurred. The system interrupt flags are set depending on the setting of GIL (CANGIM.2). If set, the global interrupts set the bits in the CANGIF1 register, otherwise they set in the CANGIF0 register.

The GMIF0/GMIF1(CANGIF0.15/CANGIF1.15) bit is set depending on the setting of the MIL[n] bit that corresponds to the mailbox originating that interrupt. If the MIL[n] bit is set, the corresponding mailbox interrupt flag MIF[n] sets the GMIF1 flag in the CANGIF1 register, otherwise, it sets the GMIF0 flag.

If all interrupt flags are cleared and a new interrupt flag is set, the CAN module interrupt output line (ECAN0INT or ECAN1INT) is activated if the corresponding interrupt mask bit is set. The interrupt line stays active until the interrupt flag is cleared by the CPU by writing a 1 to the appropriate bit.

The GMIF0 (CANGIF0.15) or GMIF1 (CANGIF0.15) bit must be cleared by writing a 1 to the appropriate bit in the CANTA register or the CANRMP register (depending on mailbox configuration) and cannot be cleared in the CANGIF0/CANGIF1 register.

After clearing one or more interrupt flags, and one or more interrupt flags are still pending, a new interrupt is generated. The interrupt flags are cleared by writing a 1 to the corresponding bit location. If the GMIF0 or GMIF1 bit is set, the mailbox interrupt vector MIV0 (CANGIF0.4-0) or MIV1 (CANGIF1.4-0) indicates the mailbox number of the mailbox that caused the setting of the GMIF0/1. It always displays the highest mailbox interrupt vector assigned to that interrupt line.

#### 12.7.4.2 Mailbox Interrupt

Each of the 32 mailboxes in the eCAN or the 16 mailboxes in the SCC can initiate an interrupt on one of the two interrupt output lines 1 or 0. These interrupts can be receive or transmit interrupts depending on the mailbox configuration.

There is one interrupt mask bit (MIM[n]) and one interrupt level bit (MIL[n]) dedicated to each mailbox. To generate a mailbox interrupt upon a receive/transmit event, the MIM bit has to be set. If a CAN message is received (RMP[n]=1) in a receive mailbox or transmitted (TA[n]=1) from a transmit mailbox, an interrupt is asserted. If a mailbox is configured as remote request mailbox (CANMD[n]=1, MSGCTRL.RTR=1), an interrupt occurs upon reception of the reply frame. A remote reply mailbox generates an interrupt upon successful transmission of the reply frame (CANMD[n]=0, MSGID.AAM=1).

The setting of the RMP[n] bit or the TA[n] bit also sets the GMIF0/GMIF1 (GIF0.15/GIF1.15) flag in the GIF0/GIF1 register if the corresponding interrupt mask bit is set. The GMIF0/GMIF1 flag then generates an interrupt and the corresponding mailbox vector (= mailbox number) can be read from the bit field MIV0/MIV1 in the GIF0/GIF1 register. If more than one mailbox interrupts are pending, the actual value of MIV0/MIV1 reflects the highest priority interrupt vector. The interrupt generated depends on the setting in the mailbox interrupt level (MIL) register.

The abort acknowledge flag (AA[n]) and the abort acknowledge interrupt flag (AAIF) in the GIF0/GIF1 register are set when a transmit message is aborted by setting the TRR[n] bit. An interrupt is asserted upon transmission abortion if the mask bit AAIM in the GIM register is set. Clearing the AA[n] flag(s) clears the AAIF0/AAIF1 flag.

A lost receive message is notified by setting the receive message lost flag RML[n] and the receive message lost interrupt flag RMLIF0/RMLIF1 in the GIF0/GIF1 register. If an interrupt shall be generated upon the lost receive message event, the receive message lost interrupt mask bit (RMLIM) in the GIM register has to be set. Clearing the RML[n] flag does not reset the RMLIF0/RMLIF1 flag. The interrupt flag has to be cleared separately.

Each mailbox of the eCAN (in eCAN mode only) is linked to a message- object, time-out register (MOTO). If a time-out event occurs (TOS[n] = 1), a mailbox timeout interrupt is asserted to one of the two interrupt lines if the mailbox timeout interrupt mask bit (MTOM) in the CANGIM register is set. The interrupt line for mailbox timeout interrupt is selected in accordance with the mailbox interrupt level (MIL[n]) of the concerned mailbox.

#### 12.7.4.3 Interrupt Handling

The CPU is interrupted by asserting one of the two interrupt lines. After handling the interrupt, which should generally also clear the interrupt source, the interrupt flag must be cleared by the CPU. To do this, the interrupt flag must be cleared in the CANGIF0 or CANGIF1 register. This is generally done by writing a 1 to the interrupt flag. There are some exceptions to this as stated in Table 12-36. This also releases the interrupt line if no other interrupt is pending.

| Interrupt |                                                   | GIF0/GIF1     |                                                                                                                   |
|-----------|---------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------|
| Flag      | Interrupt Condition                               | Determination | Clearing Mechanism                                                                                                |
| WLIFn     | One or both error counters are >= 96              | GIL bit       | Cleared by writing a 1 to it                                                                                      |
| EPIFn     | CAN module has entered "error passive" mode       | GIL bit       | Cleared by writing a 1 to it                                                                                      |
| BOIFn     | CAN module has entered "bus-off" mode             | GIL bit       | Cleared by writing a 1 to it                                                                                      |
| RMLIFn    | An overflow condition has occurred in             | GIL bit       | Cleared by clearing the set RMPn                                                                                  |
|           | one of the receive mailboxes.                     |               | bit.                                                                                                              |
| WUIFn     | CAN module has left the local power-down mode     | GIL bit       | Cleared by writing a 1 to it                                                                                      |
| WDIFn     | A write access to a mailbox was denied            | GIL bit       | Cleared by writing a 1 to it                                                                                      |
| AAIFn     | A transmission request was aborted                | GIL bit       | Cleared by clearing the set AAn bit.                                                                              |
| GMIFn     | One of the mailboxes successfully                 | MILn bit      | Cleared by appropriate handling of                                                                                |
|           | transmitted/received a message                    |               | the interrupt causing condition. Cleared by<br>writing a 1 to the ap-propriate bit in CANT<br>or CANRMP registers |
| TCOFn     | The MSB of the the TSC has changed from 0 to 1    | GIL bit       | Cleared by writing a 1 to it                                                                                      |
| MTOFn     | One of the mailboxes did not                      | MILn bit      | Cleared by clearing the set TOSn                                                                                  |
|           | transmit/receive within the specified time frame. |               | bit.                                                                                                              |

#### Table 12-36. eCAN Interrupt Assertion/Clearing<sup>(1)</sup>

<sup>(1)</sup> Key to interpreting the table above:

1) Interrupt flag: This is the name of the interrupt flag bit as applicable to CANGIF0/CANGIF1 registers.

2) Interrupt condition: This column illustrates the conditions that cause the interrupt to be asserted.

3) GIF0/GIF1 determination: Interrupt flag bits can be set in either CANGIF0 or CANGIF1 registers. This is determined by either the GIL bit in CANGIM register or MILn bit in the CANMIL register, depending on the interrupt under consideration. This column illustrates whether a particular interrupt is dependent on GIL bit or MILn bit.

4) Clearing mechanism: This column explains how a flag bit can be cleared. Some bits are cleared by writing a 1 to it. Other bits are cleared by manipulating some other bit in the CAN control register.

#### 12.7.4.3.1 Configuring for Interrupt Handling

To configure for interrupt handling, the mailbox interrupt level register (CANMIL), the mailbox interrupt mask register (CANMIM), and the global interrupt mask register (CANGIM) need to be configured. The steps to do this are described below:

- 1. Write the CANMIL register. This defines whether a successful transmission asserts interrupt line 0 or 1. For example, CANMIL = 0xFFFFFFF sets all mailbox interrupts to level 1.
- 2. Configure the mailbox interrupt mask register (CANMIM) to mask out the mailboxes that should not cause an interrupt. This register could be set to 0xFFFFFFF, which enables all mailbox interrupts. Mailboxes that are not used do not cause any interrupts anyhow.
- 3. Now configure the CANGIM register. The flags AAIM, WDIM, WUIM, BOIM, EPIM, and WLIM (GIM.14-9) should always be set (enabling these interrupts). In addition, the GIL (GIM.2) bit can be set to have the global interrupts on another level than the mailbox interrupts. Both the I1EN (GIM.1) and I0EN (GIM.0) flags should be set to enable both interrupt lines. The flag RMLIM (GIM.11) can also be set depending on the load of the CPU.

eCAN Configuration



#### eCAN Configuration

This configuration puts all mailbox interrupts on line 1 and all system interrupts on line 0. Thus, the CPU can handle all system interrupts (which are always serious) with high priority, and the mailbox interrupts (on the other line) with a lower priority. All messages with a high priority can also be directed to the interrupt line 0.

#### 12.7.4.3.2 Handling Mailbox Interrupts

There are three interrupt flags for mailbox interrupts. These are listed below:

GMIF0/GMIF1: One of the objects has received or transmitted a message. The number of the mailbox is in MIV0/MIV1(GIF0.4-0/GIF1.4-0). The normal handling routine is as follows:

- Do a half-word read on the GIF register that caused the interrupt. If the value is negative, a mailbox caused the interrupt. Otherwise, check the AAIF0/AAIF1 (GIF0.14/GIF1.14) bit (abort-acknowledge interrupt flag) or the RMLIF0/RMLIF1 (GIF0.11/GIF1.11) bit (receive-message-lost interrupt flag). Otherwise, a system interrupt has occurred. In this case, each of the system-interrupt flags must be checked.
- 2. If the RMLIF (GIF0.11) flag caused the interrupt, the message in one of the mailboxes has been overwritten by a new one. This should not happen in normal operation. The CPU needs to clear that flag by writing a 1 to it. The CPU must check the receive-message-lost register (RML) to find out which mailbox caused that interrupt. Depending on the application, the CPU has to decide what to do next. This interrupt comes together with an GMIF0/GMIF1 interrupt.
- 3. If the AAIF (GIF.14) flag caused the interrupt, a send transmission operation was aborted by the CPU. The CPU should check the abort acknowledge register (AA.31-0) to find out which mailbox caused the interrupt and send that message again if requested. The flag must be cleared by writing a 1 to it.
- 4. If the GMIF0/GMIF1 (GIF0.15/GIF1.15) flag caused the interrupt, the mailbox number that caused the interrupt can be read from the MIV0/MIV1 (GIF0.4-0/GIF1.4-0) field. This vector can be used to jump to a location where that mailbox is handled. If it is a receive mailbox, the CPU should read the data as described above and clear the RMP.31-0 flag by writing a 1 to it. If it is a send mailbox, no further action is required, unless the CPU needs to send more data. In this case, the normal send procedure as described above is necessary. The CPU needs to clear the transmit acknowledge bit (TA.31-0) by writing a 1 to it.

#### 12.7.4.3.3 Interrupt Handling Sequence

In order for the CPU core to recognize and service CAN interrupts, the following must be done in any CAN ISR:

- 1. The flag bit in the CANGIF0/CANGIF1 register which caused the interrupt in the first place must be cleared. There are two kinds of bits in these registers:
  - (a) the very same bit that needs to be cleared. The following bits fall under this category: TCOFn, WDIFn, WUIFn, BOIFn, EPIFn, WLIFn
  - (b) The second group of bits are cleared by writing to the corresponding bits in the associated registers. The following bits fall under this category: MTOFn, GMIFn, AAIFn, RMLIFn
    - (i) The MTOFn bit is cleared by clearing the corresponding bit in the TOS register. For example, if mailbox 27 caused a time-out condition due to which the MTOFn bit was set, the ISR (after taking appropriate actions for the timeout condition) needs to clear the TOS27 bit in order to clear the MTOFn bit.
    - (ii) The GMIFn bit is cleared by clearing the appropriate bit in TA or RMP register. For example, if mailbox 19 has been configured as a transmit mailbox and has completed a transmission, TA19 is set, which in turn sets GMIFn. The ISR (after taking appropriate actions) needs to clear the TA19 bit in order to clear the GMIFn bit. If mailbox 8 has been configured as a receive mailbox and has completed a reception, RMP8 is set, which in turn sets GMIFn. The ISR (after taking appropriate actions) needs to clear taking appropriate actions) needs to clear the RMP8 bit in order to clear the GMIFn bit.
    - (iii) The AAIFn bit is cleared by clearing the corresponding bit in the AA register. For example, if mailbox 13's transmission was aborted due to which the AAIFn bit was set, the ISR needs to clear the AA13 bit in order to clear the AAIFn bit.
    - (iv) The RMLIFn bit is cleared by clearing the corresponding bit in the RMP register. For example, if mailbox 13's message was overwritten due to which the RMLIFn bit was set, the ISR needs to

clear the RMP13 bit in order to clear the RMLIFn bit.

2. The PIEACK bit corresponding corresponding to the CAN module must be written with a 1, which can be accomplished with the following C language statement:

PieCtrlRegs.PIEACK.bit.ACK9 = 1; // Enables PIE to drive a pulse into the CPU

3. The interrupt line into the CPU corresponding to the CAN module must be enabled, which can be accomplished with the following C language statement:

IER  $|= 0 \times 0100; // Enable INT9$ 

4. The CPU interrupts must be enabled globally by clearing the INTM bit.

# 12.7.5 CAN Power-Down Mode

A local power-down mode has been implemented where the CAN module internal clock is de-activated by the CAN module itself.

#### 12.7.5.1 Entering and Exiting Local Power-Down Mode

During local power-down mode, the clock of the CAN module is turned off (by the CAN module itself) and only the wake-up logic is still active. The other peripherals continue to operate normally.

The local power-down mode is requested by writing a 1 to the PDR (CANMC.11) bit, allowing transmission of any packet in progress to complete. After the transmission is completed, the status bit PDA (CANES.3) is set. This confirms that the CAN module has entered the power-down mode.

The value read on the CANES register is 0x08 (PDA bit is set). All other register read accesses deliver the value 0x00.

The module leaves the local power-down mode when the PDR bit is cleared or if any bus activity is detected on the CAN bus line (if the wake-up-on bus activity is enabled).

The automatic wake-up-on bus activity can be enabled or disabled with the configuration bit WUBA of CANMC register. If there is any activity on the CAN bus line, the module begins its power-up sequence. The module waits until it detects 11 consecutive recessive bits on the CANRX pin and then it goes busactive.

**NOTE:** The first CAN message, which initiates the bus activity, cannot be received. This means that the first message received in power-down and automatic wake-up mode is lost.

After leaving the sleep mode, the PDR and PDA bits are cleared. The CAN error counters remain unchanged.

If the module is transmitting a message when the PDR bit is set, the transmission is continued until a successful transmission, a lost arbitration, or an error condition on the CAN bus line occurs. Then, the PDA bit is activated so the module causes no error condition on the CAN bus line.

To implement the local power-down mode, two separate clocks are used within the CAN module. One clock stays active all the time to ensure power-down operation (i.e., the wake-up logic and the write and read access to the PDA (CANES.3) bit). The other clock is enabled depending on the setting of the PDR bit.

# 12.7.5.2 Precautions for Entering and Exiting Device Low-Power Modes (LPM)

The DSP features two low-power modes, STANDBY and HALT, in which the peripheral clocks are turned off. Since the CAN module is connected to multiple nodes across a network, you must take care before entering and exiting device low-power modes such as STANDBY and HALT. A CAN packet must be received in full by all the nodes; therefore, if transmission is aborted half-way through the process, the aborted packet would violate the CAN protocol resulting in all the nodes generating error frames. The node exiting LPM should do so unobtrusively. For example, if a node exits LPM when there is traffic on the CAN bus it could "see" a truncated packet and disturb the bus with error frames.

The following points must be considered before entering a device low-power mode:

1. The CAN module has completed the transmission of the last packet requested.



#### eCAN Configuration

2. The CAN module has signaled to the CPU that it is ready to enter LPM.

In other words, device low-power modes should be entered into only after putting the CAN module in local power-down mode.

#### 12.7.5.3 Enabling/Disabling Clock to the CAN Module

The CAN module cannot be used unless the clock to the module is enabled. It is enabled or disabled by using bit 14 of the PCLKCR register. This bit is useful in applications that do not use the CAN module at all. In such applications, the CAN module clock can be permanently turned off, resulting in some power saving. This bit is not intended to put the CAN module in low-power mode and should not be used for that purpose. Like all other peripherals, clock to the CAN module is disabled upon reset.

#### 12.7.5.4 Possible Failure Modes External to the CAN Controller Module

This section lists some potential failure modes in a CAN based system. The failure modes listed are external to the CAN controller and hence, need to be evaluated at the system level.

- CAN\_H and CAN\_L shorted together
- CAN\_H and/or CAN\_L shorted to ground
- CAN\_H and/or CAN\_ L shorted to supply
- Failed CAN transceiver
- Electrical disturbance on CAN bus



# **Revision History**

lists the changes made since the previous version of this document.

| Chapter        | Location                                     | Additions/Modifications/Deletions                                                                                                                 |  |  |
|----------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ADC            | Section 6.1.3                                | In the third paragraph, changed "The fastest allowable sample window for the ADC is <b>7</b> cycles to <b>10</b> cycles."                         |  |  |
|                |                                              | Revised the values and/or text in the remainder of this section.                                                                                  |  |  |
|                | Section 6.1.3.1                              | Changed "The minimum number of sample cycles allowed is <b>7</b> (ACQPS= <b>6</b> ) to <b>10</b> (ACQPS= <b>9</b> ).                              |  |  |
|                | Table 6-1                                    | Revised the entire table                                                                                                                          |  |  |
|                | Figure 6-9 and Table 6-4                     | Revised the register and description table to include bit 2, CLKDIV43N                                                                            |  |  |
|                | Table 6-18                                   | Revised the ACQPS (bits 5-0) text and added a note at the end of the table                                                                        |  |  |
|                | Figure 6-32 to Figure 6-35                   | Updated figures to correspond to those in the data manual.                                                                                        |  |  |
|                | Figure 6-36                                  | Revised the figure; changed 116.67 ns to 166.67ns; changed 7 ADC clocks minimum to 10 ADC clocks minimum                                          |  |  |
| AFE            | Deleted                                      | Removed CTRIPM2OCTL, CTRIPM2STS and CTRIPM2FLGCLR register                                                                                        |  |  |
|                | Section 7.2                                  | Added a fourth paragraph to this section beginning, "A pull-down resistor is connected to the output of VREFOUT and it cannot be disconnected"    |  |  |
|                | Figure 7-9                                   | Removed the DAC/COMP filter for M2                                                                                                                |  |  |
|                | Figure 7-10                                  | Removed the DAC/COMP filter for M2                                                                                                                |  |  |
|                | Figure 7-13                                  | Removed CTRIPOUT for M2                                                                                                                           |  |  |
|                | Figure 7-22                                  | Changed bits 0-1, 4-5, and 8-9 from R/W-0 to R-0                                                                                                  |  |  |
|                | Figure 7-14                                  | Removed the DAC/COMP filter for M2                                                                                                                |  |  |
|                | Table 7-2                                    | Changed DAC3CTL and DAC4CTL to Reserved                                                                                                           |  |  |
|                | Table 7-16                                   | Removed nonfunctional COMPs/FILTS                                                                                                                 |  |  |
|                | Table 7-6 and                                | Changed bits 3 and 2 to Reserved                                                                                                                  |  |  |
|                | Figure 7-20 and Table 7-9                    | Changed bits 8, 10, and 12 to Reserved                                                                                                            |  |  |
|                | and Table 7-15                               | Changed bits 5, 4, and 2 to Reserved                                                                                                              |  |  |
|                | Section 7.9.4.1, Figure 7-26, and Table 7-17 | Removed nonfunctional COMPs (A6, B4, B6)                                                                                                          |  |  |
|                | Section 7.9.4.3, Figure 7-28, and Table 7-19 | Removed nonfunctional CTRIPs (A6, B4, B6)                                                                                                         |  |  |
|                | Section 7.9.4.4, Figure 7-29, and Table 7-20 | Removed nonfunctional CTRIPs (A6, B4, B6)                                                                                                         |  |  |
|                | Figure 7-36 and Table 7-28                   | Changed bit 1 from CTRIPM2LOCK to Reserved<br>For bit 2, changed R/W-0 to R/W-X<br>Added definition of X in the Legend                            |  |  |
|                | Figure 7-37 and Table 7-29                   | Changed bits 2 and 3 to Reserved<br>For bit 4, changed R/W-0 to R/W-X<br>For bit 5, changed R/W-X to R/W-0<br>Added definition of X in the legend |  |  |
|                | Section 7.9.5.3                              | Changed bit 4 from R/W-0 to R/W-X; added definition of X in the legend For bit 3, changed R/W-0 to R-1                                            |  |  |
| System Control | Section 1.3.1                                | Removed references to AIO                                                                                                                         |  |  |
|                | Section 1.3.5                                | Removed references of GPIO15 and replaced with GPIO5.<br>Changed GPAMUX[11:10] to GPAMUX1[11:10]                                                  |  |  |

## Table A-1. Revisions for this TRM

| Chapter | Location Additions/Modifications/Deletions |                                                                                                 |  |  |
|---------|--------------------------------------------|-------------------------------------------------------------------------------------------------|--|--|
|         | Section 1.6                                | Removed " eliminating a need for any external voltage supervisory circuits" from the paragraph. |  |  |
|         | Section 1.6.2                              | Deleted the first sentence of the paragraph and defined the acronyms POR and BOR.               |  |  |
|         | Table 1-9                                  | Add PCLKCR4 0x0000-7024 1 Peripheral Clock Control Register 4                                   |  |  |
|         | Figure 1-11                                | Removed LIN; revised channel numbers and AFE(need to do)                                        |  |  |
|         | Figure 1-15<br>and Table 1-13              | Changed bits 5-3 to Reserved                                                                    |  |  |
|         | Table 1-53<br>and Table 1-54               | Removed CTRIPM2OUT                                                                              |  |  |
|         | Table 1-86                                 | Moved PCLKCR4 to the correct position underneath WDCNTR                                         |  |  |

 Table A-1. Revisions for this TRM (continued)

#### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, enhancements, improvements and other changes to its semiconductor products and services per JESD46, latest issue, and to discontinue any product or service per JESD48, latest issue. Buyers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All semiconductor products (also referred to herein as "components") are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its components to the specifications applicable at the time of sale, in accordance with the warranty in TI's terms and conditions of sale of semiconductor products. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by applicable law, testing of all parameters of each component is not necessarily performed.

TI assumes no liability for applications assistance or the design of Buyers' products. Buyers are responsible for their products and applications using TI components. To minimize the risks associated with Buyers' products and applications, Buyers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI components or services are used. Information published by TI regarding third-party products or services does not constitute a license 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 significant portions 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. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI components or services with statements different from or beyond the parameters stated by TI for that component or service voids all express and any implied warranties for the associated TI component or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

Buyer acknowledges and agrees that it is solely responsible for compliance with all legal, regulatory and safety-related requirements concerning its products, and any use of TI components in its applications, notwithstanding any applications-related information or support that may be provided by TI. Buyer represents and agrees that it has all the necessary expertise to create and implement safeguards which anticipate dangerous consequences of failures, monitor failures and their consequences, lessen the likelihood of failures that might cause harm and take appropriate remedial actions. Buyer will fully indemnify TI and its representatives against any damages arising out of the use of any TI components in safety-critical applications.

In some cases, TI components may be promoted specifically to facilitate safety-related applications. With such components, TI's goal is to help enable customers to design and create their own end-product solutions that meet applicable functional safety standards and requirements. Nonetheless, such components are subject to these terms.

No TI components are authorized for use in FDA Class III (or similar life-critical medical equipment) unless authorized officers of the parties have executed a special agreement specifically governing such use.

Only those TI components which TI has specifically designated as military grade or "enhanced plastic" are designed and intended for use in military/aerospace applications or environments. Buyer acknowledges and agrees that any military or aerospace use of TI components which have *not* been so designated is solely at the Buyer's risk, and that Buyer is solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI has specifically designated certain components as meeting ISO/TS16949 requirements, mainly for automotive use. In any case of use of non-designated products, TI will not be responsible for any failure to meet ISO/TS16949.

| Products                     |                          | Applications                  |                                   |
|------------------------------|--------------------------|-------------------------------|-----------------------------------|
| Audio                        | www.ti.com/audio         | Automotive and Transportation | www.ti.com/automotive             |
| Amplifiers                   | amplifier.ti.com         | Communications and Telecom    | www.ti.com/communications         |
| Data Converters              | dataconverter.ti.com     | Computers and Peripherals     | www.ti.com/computers              |
| DLP® Products                | www.dlp.com              | Consumer Electronics          | www.ti.com/consumer-apps          |
| DSP                          | dsp.ti.com               | Energy and Lighting           | www.ti.com/energy                 |
| Clocks and Timers            | www.ti.com/clocks        | Industrial                    | www.ti.com/industrial             |
| Interface                    | interface.ti.com         | Medical                       | www.ti.com/medical                |
| Logic                        | logic.ti.com             | Security                      | www.ti.com/security               |
| Power Mgmt                   | power.ti.com             | Space, Avionics and Defense   | www.ti.com/space-avionics-defense |
| Microcontrollers             | microcontroller.ti.com   | Video and Imaging             | www.ti.com/video                  |
| RFID                         | www.ti-rfid.com          |                               |                                   |
| OMAP Applications Processors | www.ti.com/omap          | TI E2E Community              | e2e.ti.com                        |
| Wireless Connectivity        | www.ti.com/wirelessconne | ectivity                      |                                   |

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2013, Texas Instruments Incorporated